从Oracle数据库访问googleapis(地图)时出现问题
我正在尝试使用谷歌地图API获取LAT和LON详细信息“=“我的钥匙” 我想从Oracle数据库运行此操作,为此我需要向Oracle数据库添加ACL条目,但当我尝试添加ACL时,会收到错误通知,如下所示从Oracle数据库访问googleapis(地图)时出现问题,oracle,plsql,google-api,database-connection,Oracle,Plsql,Google Api,Database Connection,我正在尝试使用谷歌地图API获取LAT和LON详细信息“=“我的钥匙” 我想从Oracle数据库运行此操作,为此我需要向Oracle数据库添加ACL条目,但当我尝试添加ACL时,会收到错误通知,如下所示 BEGIN dbms_network_acl_admin.CREATE_ACL( acl => 'ACL_GM.xml', description => 'ACL FOR GOOGLE MAPS API', principal => 'ADM_KSV
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
如何避免错误?您不应该将URL作为
主机
参数传递;顾名思义,它应该只是URL的主机(名称或IP)部分。该协议由端口号参数启用,并且仅对于https,您需要指定端口443
报告说:
host—要向其分配ACL的主机。主机可以是主机的名称或IP地址。通配符可用于指定域或IP子网。主机名或域名不区分大小写
lower_port—如果不为NULL,则TCP端口范围的下限
upper_port—TCP端口范围的上限。如果为NULL,则假定为较低的_端口
在这种情况下,当您访问外部资源时,它应该是完全限定的域名。因此,您可以:
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\u port
null保留为空,这将具有相同的效果