ORACLE PL/SQL调用WEBSERVICE多种方式详解

在使用PL/SQL访问HTTP网站时一般使用工具包UTL_HTTP调用webservice。

调用基于json数据传输的restful webservice

以文本方式传输request内容

   l_rest_requst := utl_url.escape(p_requst_data,
                                   TRUE,
                                   'utf8');

   l_http_url := p_http_url;
   -- preparing Request...
   l_http_request := utl_http.begin_request(l_http_url,
                                            'POST',
                                            'HTTP/1.1');

   -- ...set header's attributes
   utl_http.set_header(l_http_request,
                       'Content-Type',
                       'application/json;charset="utf-8"');

   utl_http.set_header(l_http_request,
                       'Content-Length',
                       length(l_rest_requst));

   utl_http.write_text(l_http_request,
                       l_rest_requst);

   l_http_response := utl_http.get_response(l_http_request);
   dbms_output.put_line(l_http_response.status_code);
   utl_http.read_text(l_http_response,
                      l_soap_respond);
   l_soap_respond := utl_url.unescape(l_soap_respond,
                                      'utf8');
   utl_http.end_response(l_http_response);

以二进制方式传输request内容

传输的数据中如果有中文,用文本方式传输通常会返回400错误,这时可以将传输的json串转换成raw类型,并且设置transfer-encoding为chunked。

  l_soap_request := utl_i18n.string_to_raw(p_requst_data,
                                            'UTF8');

   l_http_url     := p_http_url;
   utl_http.set_transfer_timeout(3600);
   -- preparing Request...
   l_http_request := utl_http.begin_request(l_http_url,
                                            'POST',
                                            'HTTP/1.1');
   get_token(x_return_status => x_return_status,
             x_msg_count     => x_msg_count,
             x_msg_data      => x_msg_data,
             p_token_str     => l_token_str,
             p_token_type    => l_token_type);
   
   utl_http.set_header(l_http_request,
                       'Authorization',
                       l_token_type || ' ' || l_token_str
                      );

   utl_http.set_header(l_http_request,
                       'Content-Type',
                       'application/json;charset="utf-8"'
                       );
   UTL_HTTP.set_header(l_http_request, 'Transfer-Encoding', 'chunked');
   UTL_HTTP.SET_HEADER(l_http_request, 'User-Agent', 'Mozilla/4.0');
   utl_http.set_body_charset('UTF-8');
   utl_http.write_text(l_http_request, UTL_TCP.crlf || UTL_TCP.crlf);
   utl_http.write_raw(l_http_request,
                      l_soap_request);

   l_http_response := utl_http.get_response(l_http_request);

   utl_http.read_raw(l_http_response,
                     l_soap_respond);

   utl_http.end_response(l_http_response);
   l_soap_respond_text := utl_raw.cast_to_varchar2(l_soap_respond);

调用基于xml数据传输的soap webservice

// A code block
    l_http_request := utl_http.begin_request(p_http_url,
                                             'POST',
                                             'HTTP/1.1');
    utl_http.set_header(l_http_request,
                        'Content-Type',
                        'text/xml; charset=utf-8');
    utl_http.set_header(l_http_request,
                        'Content-Length',
                        length(p_request_data));
    utl_http.set_header(l_http_request,
                        'SOAPAction',
                        p_http_url);
    utl_http.write_text(l_http_request,
                        p_request_data);
    l_http_response := utl_http.get_response(l_http_request);
    utl_http.read_text(l_http_response,
                       l_buffer);
    utl_http.end_response(l_http_response);

获取token的函数

前面用到的get_token的方法也是用utl_http这个包,关键是要先知道从对方的哪个链接能够获取token,以及对方返回token时格式,代码片段如下:

    l_base64     := utl_encode.base64_encode(utl_i18n.string_to_raw(l_username || ':' ||
                                                                    l_password,
                                                                    'AL32UTF8'));
    l_base64_str := utl_raw.cast_to_varchar2(l_base64);
  
    SELECT REPLACE(REPLACE(l_base64_str,
                           chr(13),
                           ''),
                   chr(10),
                   '')
      INTO l_base64_str1
      FROM dual;
  

    l_http_request := utl_http.begin_request(l_http_url,
                                             'POST',
                                             'HTTP/1.1');
  
    utl_http.set_header(l_http_request,
                        'Authorization',
                        'Basic ' || l_base64_str1);
  
    utl_http.write_raw(l_http_request,
                       l_soap_requst);
  
    l_http_response := utl_http.get_response(l_http_request);
  
    IF l_http_response.status_code = utl_http.http_ok THEN
      NULL;
      dbms_output.put_line(l_http_response.status_code);
    ELSE
      x_return_status := fnd_api.g_ret_sts_error;
      raise_exception(x_return_status);
    END IF;
  
    BEGIN
      utl_http.read_text(l_http_response,
                         l_soap_respond);
      utl_http.end_response(l_http_response);
    
      dbms_output.put_line(l_soap_respond);
    
      p_token_str  := substr(l_soap_respond,
                             instr(l_soap_respond,
                                   '":"',
                                   1,
                                   1) + 3,
                             instr(l_soap_respond,
                                   '","',
                                   1,
                                   1) - instr(l_soap_respond,
                                              '":"',
                                              1,
                                              1) - 3);
      p_token_type := substr(l_soap_respond,
                             instr(l_soap_respond,
                                   '":"',
                                   1,
                                   2) + 3,
                             instr(l_soap_respond,
                                   '","',
                                   1,
                                   2) - instr(l_soap_respond,
                                              '":"',
                                              1,
                                              2) - 3);
    
    EXCEPTION
      WHEN OTHERS THEN
        NULL;
    END;
  • 3
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
智慧校园整体解决方案是响应国家教育信息化政策,结合教育改革和技术创新的产物。该方案以物联网、大数据、人工智能和移动互联技术为基础,旨在打造一个安全、高效、互动且环保的教育环境。方案强调从数字化校园向智慧校园的转变,通过自动数据采集、智能分析和按需服务,实现校园业务的智能化管理。 方案的总体设计原则包括应用至上、分层设计和互联互通,确保系统能够满足不同用户角色的需求,并实现数据和资源的整合与共享。框架设计涵盖了校园安全、管理、教学、环境等多个方面,构建了一个全面的校园应用生态系统。这包括智慧安全系统、校园身份识别、智能排课及选课系统、智慧学习系统、精品录播教室方案等,以支持个性化学习和教学评估。 建设内容突出了智慧安全和智慧管理的重要性。智慧安全管理通过分布式录播系统和紧急预案一键启动功能,增强校园安全预警和事件响应能力。智慧管理系统则利用物联网技术,实现人员和设备的智能管理,提高校园运营效率。 智慧教学部分,方案提供了智慧学习系统和精品录播教室方案,支持专业级学习硬件和智能化网络管理,促进个性化学习和教学资源的高效利用。同时,教学质量评估中心和资源应用平台的建设,旨在提升教学评估的科学性和教育资源的共享性。 智慧环境建设则侧重于基于物联网的设备管理,通过智慧教室管理系统实现教室环境的智能控制和能效管理,打造绿色、节能的校园环境。电子班牌和校园信息发布系统的建设,将作为智慧校园的核心和入口,提供教务、一卡通、图书馆等系统的集成信息。 总体而言,智慧校园整体解决方案通过集成先进技术,不仅提升了校园的信息化水平,而且优化了教学和管理流程,为学生、教师和家长提供了更加便捷、个性化的教育体验。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值