我正在尝试使用Oracle UTL_HTTP.request
API调用Web服务。通话需要代理和钱包/证书。我相信我已经解决了证书问题,因为我不再遇到ORA-29024: Certificate validation failure
错误。现在,我收到ORA-29259: end-of-input reached
错误。我正在使用DBMS版本12.1.0.2.0,并且应该使用TLS 1.2(不确定如何验证这一点)。
以下调用可以正常工作并返回JSON负载:
SELECT utl_http.request (
'http://jsonplaceholder.typicode.com/todos/1',
'proxy.myurl.com')
FROM dual;
响应:
{
"userId": 1,
"id": 1,
"title": "delectus aut autem",
"completed": false
}
以下调用会引发ORA-29259错误:
SELECT utl_http.request (
'https://service.baseurl.com/ping',
'proxy.myurl.com',
'file:/my/wallet/location',
'mypassword'
)
FROM DUAL;
运行时异常堆栈:
ORA-29273: HTTP request failed
ORA-29259: end-of-input reached
ORA-06512: at "SYS.UTL_HTTP", line 1491
ORA-06512: at line 1
我也尝试过使用匿名PL / SQL块调用UTL_HTTP.begin_request
,但基本上得到与上述相同的ORA-29259
错误。
DECLARE
l_http_request utl_http.req;
l_http_response utl_http.resp;
l_text VARCHAR2(32767);
BEGIN
utl_http.set_proxy('proxy.myurl.com');
utl_http.set_wallet('file:/my/wallet/location'
,'mypassword');
l_http_request := utl_http.begin_request('https://service.baseurl.com/ping'
,'POST', 'HTTP/1.1');
l_http_response := utl_http.get_response(l_http_request);
BEGIN
LOOP
utl_http.read_text(l_http_response, l_text, 32766);
dbms_output.put_line(l_text);
END LOOP;
EXCEPTION WHEN utl_http.end_of_body THEN
utl_http.end_response(l_http_response);
END;
END;
ORA-29273: HTTP request failed
ORA-29259: end-of-input reached
ORA-06512: at "SYS.UTL_HTTP", line 1258
ORA-06512: at line 10
关于什么可能导致此错误的任何想法?
答案 0 :(得分:0)
我认为您的问题将是12.1c中缺少密码套件。 您必须在数据库上应用安全补丁24666032,并且最小DBBP应该为12.1.0.2.160719(23054246)。
此后,数据库应添加对密码的支持。
您可以在MOS上查看此信息:UTL_HTTP在12c数据库(文档ID 2402276.1)中访问ORA-29259导致无法访问安全网站
致谢