从Oracle数据库访问googleapis(MAPS)时出现的问题

时间:2016-02-09 17:51:49

标签: oracle plsql google-api database-connection

我正在尝试使用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

如何避免错误?

1 个答案:

答案 0 :(得分:1)

您不应将URL作为host参数传递;顾名思义它应该只是URL的主机(名称或IP)部分。该协议由端口号参数启用,对于https,您只需要指定端口443。

documentation说:

  

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保留为具有相同效果。