Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/9.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
从Oracle数据库访问googleapis(地图)时出现问题_Oracle_Plsql_Google Api_Database Connection - Fatal编程技术网

从Oracle数据库访问googleapis(地图)时出现问题

从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

我正在尝试使用谷歌地图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_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保留为空,这将具有相同的效果