I am trying to talk with Google calendar. I have problem with authentication. I write down the code below.
create or replace function authenticate_service(
p_email in varchar2,
p_password in varchar2) return varchar2 is
l_request utl_http.req;
l_response utl_http.resp;
l_params varchar2(255);
l_resp_data varchar2(4000);
l_auth_token varchar2(4000); begin
-- access the oracle wallet to allow us to make an https request
utl_http.set_wallet(
path => 'file: ***',
password => '***');
-- set up the request body with our credentials
l_params := 'Email=' || p_email || '&Passwd=' || p_password ||
'&service=cl' || '&source=e-DBA-test-1.0';
l_request := utl_http.begin_request(
'https://www.google.com/accounts/ClientLogin',
'POST',
'HTTP/1.1');
-- set the request headers
utl_http.set_header(
l_request,
'Content-Type',
'application/x-www-form-urlencoded');
utl_http.set_header(
l_request,
'Content-Length',
length(l_params));
-- write out the request body
utl_http.write_text( l_request, l_params );
-- get the response
l_response := utl_http.get_response( r => l_request );
dbms_output.put_line('Status Code: '||l_response.status_code);
begin
loop
utl_http.read_line( r => l_response, data => l_resp_data,remove_crlf => TRUE);
if substr(l_resp_data, 1, 5) = 'Auth=' then
l_auth_token := substr(l_resp_data, 6);
end if;
end loop;
exception
when utl_http.end_of_body then
null;
end;
utl_http.end_response ( l_response );
dbms_output.put_line(l_auth_token); return l_auth_token;
end authenticate_service;
Everything works fine but... When I try to call authentication a few times a row, sometimes I found this error Oracle ORA-03113: end-of-file on communication channel and then ORA-03114: not connected to ORACLE. I have no idea why it happens and how to fix this.
Exception [type: SIGSEGV, Address not mapped to object] [ADDR:0xAE0BE38] [PC:0x7FEBB33A7F8A, nzos_Create_Ctx()+264] [flags: 0x0, count: 1]
andORA-07445: napotkano wyj±tek: zrzut pamięci [nzos_Create_Ctx()+264] [SIGSEGV] [ADDR:0xAE0BE38] [PC:0x7FEBB33A7F8A] [Address not mapped to object] []
– widzimusie