oracle使用utl_http包傳送post請求

lsq_008發表於2016-04-21
使用plsq傳送post或get請求,開始傳送中文時有亂碼,網上搜了半天,終於找到解決辦法,關鍵點見紅色字型部分,記錄以備忘:
set serveroutput on;
exec dbms_output.enable(1000000000);
set escape '\'
DECLARE
  req   UTL_HTTP.REQ;
  resp  UTL_HTTP.RESP;
  value VARCHAR2(1024);  -- URL to post to
   v_url VARCHAR2(200) := 'http://ip:port/xxx';
  -- Post Parameters
  v_param VARCHAR2(500) := 'para1=xxx\?2=xxxx\?3=xxxx';
  v_param_length NUMBER := LENGTHB(v_param);
BEGIN
  -- Set up proxy servers if required
  --  UTL_HTTP.SET_PROXY('proxy.my-company.com', 'corp.my-company.com');
  req := UTL_HTTP.BEGIN_REQUEST (url=> v_url, method => 'POST');
  --  UTL_HTTP.SET_HEADER(req, 'User-Agent', 'Mozilla/4.0');
  UTL_HTTP.SET_BODY_CHARSET('UTF-8');
  UTL_HTTP.SET_HEADER (r      =>  req,
                       name   =>  'Content-Type',
                       value  =>  'application/x-www-form-urlencoded');
  UTL_HTTP.SET_HEADER (r      =>   req,
                       name   =>   'Content-Length',
                       value  =>   v_param_length);
  UTL_HTTP.WRITE_RAW (r    => req,
                    data => UTL_RAW.CAST_TO_RAW(v_param)); 
  resp := UTL_HTTP.GET_RESPONSE(req);
  LOOP
    UTL_HTTP.READ_LINE(resp, value, TRUE);
    DBMS_OUTPUT.PUT_LINE(value);
  END LOOP;
  UTL_HTTP.END_RESPONSE(resp);
EXCEPTION
  WHEN UTL_HTTP.END_OF_BODY THEN
    UTL_HTTP.END_RESPONSE(resp);
END;
/

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10972173/viewspace-2085171/,如需轉載,請註明出處,否則將追究法律責任。

相關文章