我正在尝试使用google maps API来获取LAT和LON详细信息“https://maps.googleapis.com/maps/api/geocode/XML?components=postal_code:1080|country:BE&key =”我的密钥“”。
我想从Oracle数据库运行这个,我需要为oracle数据库添加一个ACL条目,但是当我尝试添加ACL时,我会收到错误通知,如下所示
BEGIN
dbms_network_acl_admin.CREATE_ACL(
acl => 'ACL_GM.xml',
description => 'ACL FOR GOOGLE MAPS API',
principal => 'ADM_KSVIJAYA',
is_grant => TRUE,
privilege => 'connect',
start_date => NULL,
end_date => NULL);
COMMIT;
END;
PL/SQL PROCEDURE successfully completed.
BEGIN
dbms_network_acl_admin.ASSIGN_ACL(
acl => 'ACL_GM.xml',
host => 'https://maps.googleapis.com',
lower_port => NULL,
upper_port => NULL);
COMMIT;
END;
BEGIN
*
ERROR at line 1:
ORA-24244: invalid host or port for access control list (ACL) assignment
ORA-06512: at "SYS.DBMS_NETWORK_ACL_ADMIN", line 164
ORA-06512: at "SYS.DBMS_NETWORK_ACL_ADMIN", line 485
ORA-06512: at line 2
如何避免错误?
答案 0 :(得分:1)
您不应将URL作为host
参数传递;顾名思义它应该只是URL的主机(名称或IP)部分。该协议由端口号参数启用,对于https,您只需要指定端口443。
host - 要为其分配ACL的主机。主机可以是主机的名称或IP地址。通配符可用于指定域或IP子网。主机或域名不区分大小写。
lower_port - TCP端口范围的下限,如果不是NULL
upper_port - TCP端口范围的上限。如果为NULL,则假定lower_port为
在这种情况下,当您访问外部资源时,它应该是完全限定的域名。所以你可以这样做:
BEGIN
DBMS_NETWORK_ACL_ADMIN.UNASSIGN_ACL (
acl => 'ACL_GM.xml',
host => 'maps.googleapis.com',
lower_port => 443,
upper_port => 443);
COMMIT;
END;
/
PL/SQL procedure successfully completed.
或者您可以将upper_port
null保留为具有相同效果。