Effectuer des appels externes à l'aide d'un portefeuille géré par le client
Lorsque votre instance de base de données IA autonome se trouve sur un point d'extrémité privé, vous pouvez utiliser un portefeuille géré par le client avec des procédures dans UTL_HTTP, DBMS_LDAP, UTL_SMTP ou UTL_TCP. Vous pouvez également utiliser un portefeuille géré par le client lorsque le programmateur envoie des avis par courriel SMTP pour divers événements liés aux tâches du programmateur.
- À propos de l'utilisation d'un portefeuille géré par le client avec des appels externes
Lorsque votre instance de base de données Autonomous AI Database se trouve sur un point d'extrémité privé, vous pouvez utiliser un portefeuille géré par le client pour gérer les appels externes, ou avec le programmateur lorsque le programmateur envoie des courriels pour divers événements liés aux tâches de programmateur. - Préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes
Affiche les étapes préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes ou avec des avis par courriel SMTP du programmateur. - Utiliser un portefeuille géré par le client pour les appels externes avec UTL_HTTP
Lorsque votre instance de base de données Autonomous AI Database se trouve sur un point d'extrémité privé, vous pouvez utiliser un portefeuille géré par le client pour traiter les appels externes. - Utiliser un portefeuille géré par le client avec les avis par courriel du programmateur
Décrit les étapes à suivre pour utiliser le serveur de courriel SMTP du programmateur avec un portefeuille géré par le client. - Notes pour l'utilisation d'un portefeuille géré par le client avec des appels externes
Fournit des notes pour l'utilisation d'un portefeuille géré par le client avec des appels externes.
Rubrique parent : Développer
À propos de l'utilisation d'un portefeuille géré par le client avec des appels externes
Lorsque votre instance de base de données Autonomous AI Database se trouve sur un point d'extrémité privé, vous pouvez utiliser un portefeuille géré par le client pour gérer les appels externes, ou avec le programmateur lorsque le programmateur envoie des courriels pour divers événements liés aux tâches du programmateur.
Sur Autonomous AI Database, vous pouvez effectuer des appels externes à l'une des fins suivantes :
-
Pour utiliser les services Web avec
UTL_HTTP. -
Pour accéder aux données des serveurs LDAP à l'aide de
DBMS_LDAP. -
Pour envoyer un courriel à
UTL_SMTP. -
Pour communiquer avec des serveurs TCP/IP externes à l'aide de TCP/IP avec
UTL_TCP. -
Pour les avis par courriel de tâche d'Oracle Scheduler.
Par défaut, lorsque vous utilisez des procédures dans ces packages, Autonomous AI Database gère un portefeuille interne et utilise toujours des connexions sécurisées (le portefeuille géré par Oracle contient plus de 90 des certificats SSL racine et intermédiaire de confiance les plus courants). Lorsque votre base de données Autonomous AI Database réside sur un point d'extrémité privé, vous avez la possibilité d'utiliser le portefeuille géré par Oracle par défaut avec les certifications SLL fiables et intermédiaires, ou vous pouvez fournir un portefeuille géré par le client.
Lorsque votre base de données d'intelligence artificielle autonome réside sur un point d'extrémité privé, vous pouvez spécifier un portefeuille géré par le client pour UTL_HTTP, UTL_SMTP, DBMS_LDAP et DBMS_NETWORK_ACL_ADMIN à l'aide des procédures PL/SQL suivantes :
UTL_HTTP.SET_WALLET (
path IN VARCHAR2,
password IN VARCHAR2 DEFAULT NULL);
UTL_HTTP.REQUEST (
wallet_path IN VARCHAR2 DEFAULT NULL,
wallet_password IN VARCHAR2 DEFAULT NULL)
UTL_HTTP.REQUEST_PIECES (
wallet_p ath IN VARCHAR2 DEFAULT NULL,
wallet_password IN VARCHAR2 DEFAULT NULL,
UTL_HTTP.CREATE_REQUEST_CONTEXT (
wallet_path IN VARCHAR2 DEFAULT NULL,
wallet_password IN VARCHAR2 DEFAULT NULL)
UTL_TCP.OPEN_CONNECTION
wallet_path IN VARCHAR2 DEFAULT NULL,
wallet_password IN VARCHAR2 DEFAULT NULL);
UTL_SMTP.OPEN_CONNECTION
wallet_path IN VARCHAR2 DEFAULT NULL,
wallet_password IN VARCHAR2 DEFAULT NULL)
DBMS_LDAP.OPEN_SSL(
sslwrl IN VARCHAR2,
sslwalletpasswd IN VARCHAR2)
DBMS_NETWORK_ACL_ADMIN.APPEND_WALLET_ACE
wallet_path IN VARCHAR2
DBMS_NETWORK_ACL_ADMIN.APPEND_WALLET_ACL(
wallet_path IN VARCHAR2Dans ces appels, selon la procédure, utilisez le paramètre path ou wallet_path pour spécifier un portefeuille géré par le client. Vous définissez le répertoire de portefeuille avec le préfixe DIR: et incluez un chemin d'accès au portefeuille. Exemple :
UTL_HTTP.set_wallet('DIR:WALLET_DIR', 'password');L'utilisateur courant qui appelle l'API doit disposer des privilèges READ sur l'objet de répertoire ou disposer du privilège système CREATE ANY DIRECTORY.
Le préfixe DIR: est le formulaire privilégié à utiliser pour spécifier un portefeuille géré par le client. En outre, le préfixe file: est pris en charge. Exemple :
UTL_HTTP.set_wallet('file:WALLET_DIR/wallet.sso', 'password');Pour plus d'informations, voir Utiliser un portefeuille géré par le client pour les appels externes avec UTL_HTTP :
À propos de l'utilisation d'un portefeuille géré par le client avec le serveur de courriels du programmateur
Le serveur de courriel du programmateur est disponible pour envoyer des avis par courriel pour divers événements liés au programmateur, tels que l'avis de tâches démarrées, en échec ou terminées. Par défaut, le serveur de courriel SMTP du programmateur utilise le portefeuille défini dans la propriété SSL_WALLET pour les communications SSL/TLS. Facultativement, vous pouvez utiliser un portefeuille géré par le client avec le serveur de courriel SMTP du programmateur.
Les attributs globaux suivants prennent en charge l'utilisation d'un portefeuille géré par le client :
-
EMAIL_SERVER_WALLET_DIRECTORY: est réglé à un objet de répertoire qui spécifie le chemin d'accès au portefeuille SSL. EMAIL_SERVER_WALLET_CREDENTIAL: est réglé à un objet de données d'identification avec une paire nom d'utilisateur/mot de passe, où le nom d'utilisateur est une valeur et le mot de passe est le mot de passe du portefeuille SSL.
Vous définissez des valeurs pour ces attributs à l'aide de DBMS_SCHEDULER.SET_SCHEDULER_ATTRIBUTE.
Voir ce qui suit pour plus d'informations :
Rubrique parent : Faire des appels externes à l'aide d'un portefeuille géré par le client
Préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes
Affiche les étapes préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes ou avec des avis par courriel SMTP du programmateur.
Effectuez les étapes préalables suivantes :
Rubrique parent : Faire des appels externes à l'aide d'un portefeuille géré par le client
Utiliser un portefeuille géré par le client pour les appels externes avec UTL_HTTP
Lorsque votre instance de base de données Autonomous AI Database se trouve sur un point d'extrémité privé, vous pouvez utiliser un portefeuille géré par le client pour gérer les appels externes.
Ces étapes décrivent l'utilisation d'un portefeuille géré par le client avec UTL_HTTP. Les étapes sont les mêmes pour les autres ensembles pris en charge, notamment : DMBS_LDAP, UTL_SMTP et UTL_TCP.
Effectuez les étapes préalables pour utiliser un portefeuille géré par le client. Pour plus d'informations, voir Préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes.
Pour configurer une base de données IA autonome afin qu'elle utilise un portefeuille géré par le client :
Rubrique parent : Faire des appels externes à l'aide d'un portefeuille géré par le client
Utiliser un portefeuille géré par le client avec les avis par courriel du programmateur
Décrit les étapes à suivre pour utiliser le serveur de courriel SMTP du programmateur avec un portefeuille géré par le client.
Effectuez les étapes préalables pour utiliser un portefeuille géré par le client. Pour plus d'informations, voir Préalables à l'utilisation d'un portefeuille géré par le client avec des appels externes.
Pour utiliser un portefeuille géré par le client avec le serveur de courriel du programmateur :
Rubrique parent : Faire des appels externes à l'aide d'un portefeuille géré par le client
Notes pour l'utilisation d'un portefeuille géré par le client avec des appels externes
Fournit des notes pour l'utilisation d'un portefeuille géré par le client avec des appels externes.
-
Les demandes
DBMS_CLOUDne respectent pas le portefeuille personnalisé que vous avez défini avecUTL_HTTP.set_wallet. Cela inclutDBMS_CLOUD.SEND_REQUESTet tous les accès au stockage d'objets pour les tables externesDBMS_CLOUDque vous définissez avecDBMS_CLOUD.CREATE_EXTERNAL_TABLE,DBMS_CLOUD.CREATE_EXTERNAL_PART_TABLEouDBMS_CLOUD.CREATE_HYBRID_PART_TABLE. Lorsque vous exécutez une interrogation sur une table externe que vous avez créée avec une procédureDBMS_CLOUD, les interrogations ne respectent pas le portefeuille personnalisé que vous avez défini avecUTL_HTTP.set_wallet. -
Les demandes
APEX_WEB_SERVICEne respectent pas le portefeuille personnalisé que vous avez défini avecUTL_HTTP.set_wallet.Pour utiliser un portefeuille géré par le client avec APEX, spécifiez le paramètre
p_wallet_pathdans les appels d'APIAPEX_WEB_SERVICEou définissez le paramètre d'instance de chemin d'accès au portefeuille dans les services d'administration APEX.Pour plus d'informations, voir Accéder aux services d'administration d'Oracle APEX.
-
Les portefeuilles à connexion automatique et les portefeuilles protégés par mot de passe sont pris en charge. Lorsque vous utilisez un portefeuille à connexion automatique, spécifiez
NULLpour le paramètrewallet_password. -
L'utilisateur courant qui appelle l'API
UTL_HTTP.set_walletdoit disposer des privilègesREADsur l'objet de répertoire ou se voir accorder le privilège systèmeCREATE ANY DIRECTORY. -
L'API
UTL_HTTP.SET_AUTHENTICATION_FROM_WALLETest autorisée. Pour plus d'informations, voir ProcédureSET_AUTHENTICATION_FROM_WALLET. -
Le préfixe
file:est pris en charge avecUTL_HTTP.set_wallettant que le chemin d'accès au fichier spécifié est conforme àPATH_PREFIX.Vous pouvez déterminer la conformité
PATH_PREFIXpour un chemin fourni en entrée avec la procédureDBMS_PDB_IS_VALID_PATH(accordé àPUBLIC, y compris l'utilisateurADMIN).Exemple :
with function check_path_prefix_compliance(file_path varchar2) return varchar2 as BEGIN if dbms_pdb_is_valid_path(file_path) then return 'YES'; else return 'NO'; end if; END; SELECT check_path_prefix_compliance('/u03/dbfs/1276CDexample/data/dpdump') as PATH_PREFIX_COMPLIANT, check_path_prefix_compliance('/u01/app/oracle/diag') as PATH_PREFIX_COMPLIANT FROM dual; / -
Pour assurer la compatibilité descendante lorsque vous utilisez
UTL_HTTP.set_wallet, dans les cas où le chemin du portefeuille est ignoré, les valeurs d'entrée telles quefile:,NULL, etc., sont acceptées. Ces valeurs sont ignorées et spécifiez d'utiliser le chemin d'accès au portefeuille SSL par défaut avecUTL_HTTP.set_wallet. -
Les API de liste de contrôle d'accès du portefeuille
DBMS_NETWORK_ACL_ADMIN, telles queAPPEND_WALLET_ACL, sont prises en charge. Ces procédures vous permettent d'accorder ou de révoquer des privilèges de liste de contrôle d'accès pour le portefeuille. Pour plus d'informations, voir DBMS_NETWORK_ACL_ADMIN. -
Pour prendre en charge l'utilisation des données d'identification de mot de passe dans un portefeuille SSL pour l'authentification, l'utilisateur courant qui appelle les API
UTL_HTTPdoit disposer du privilège de liste de contrôle d'accès "use-passwords" sur le chemin du portefeuille. -
Notes pour définir
EMAIL_SERVER_WALLET_DIRECTORYetEMAIL_SERVER_WALLET_CREDENTIALavecDBMS_SCHEDULER.SET_SCHEDULER_ATTRIBUTE:-
Pour définir les valeurs d'attribut avec
DBMS_SCHEDULER.SET_SCHEDULER_ATTRIBUTE, vous devez être un utilisateur administrateur ou un utilisateur doté des privilègesMANAGE SCHEDULER(l'utilisateur ADMIN dispose de ces privilèges). - En plus du privilège
MANAGE SCHEDULER, l'utilisateur qui appelleDBMS_SCHEDULER.SET_SCHEDULER_ATTRIBUTEdoit disposer du privilègeREADsur l'objet de répertoire que vous avez défini avecEMAIL_SERVER_WALLET_DIRECTORYet du privilègeEXECUTEsur l'objet de données d'identification que vous avez défini avecEMAIL_SERVER_WALLET_CREDENTIAL.
-
Rubrique parent : Faire des appels externes à l'aide d'un portefeuille géré par le client