通过Ajax调用WebService接口(使用CORS方式解决跨域跨域问题)(WebService使用Java开发)

2 篇文章 0 订阅
1 篇文章 0 订阅

通过Ajax调用WebService接口首先需要解决Ajax跨域的问题,解决方式如下:

(1)项目中引入jar包,maven项目直接在pom.xml中添加如下依赖即可

<!--  CORS  -->
    <dependency>
      <groupId>com.thetransactioncompany</groupId>
      <artifactId>cors-filter</artifactId>
      <version>2.6</version>
    </dependency>
    <dependency>
      <groupId>com.thetransactioncompany</groupId>
      <artifactId>java-property-utils</artifactId>
      <version>1.13</version>
    </dependency>

(2)在Web.xml中添加如下配置(此filter放第一个):

<!-- CORS跨域配置 -->
    <filter>
      <filter-name>CORS</filter-name>
      <filter-class>com.thetransactioncompany.cors.CORSFilter</filter-class>
      <init-param>
        <param-name>cors.allowOrigin</param-name>
        <param-value>*</param-value>
      </init-param>
    </filter>
    <filter-mapping>
      <filter-name>CORS</filter-name>
      <url-pattern>/*</url-pattern>
    </filter-mapping>

 

Ajax调用WebService接口的方法如下:

function testBtn() {
            let testBtn = document.getElementById('testBtn');
            var paramsXml = '<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"' +
                ' xmlns:q0="proService"' +
                ' xmlns:xsd="http://www.w3.org/2001/XMLSchema"' +
                ' xmlns:xsi="http://www.w3.org/2001/XMLSchemainstance">' +
                '<soapenv:Body>' +
                '<q0:testObject>' +
                '<age>22</age>' +
                '<name>Jack</name>' +
                '</q0:testObject>' +
                '</soapenv:Body>' +
                '</soapenv:Envelope>';
            $.ajax({
                url: "http://localhost:8080/webservice_pro_war/services/proService/proService/testObject",
                type: "POST",
                dataType: "XML",
                contentType: "text/xml; charset=UTF-8",
                data: paramsXml,
                // crossDomain: true,
                beforeSend: function (XMLHttpRequest) {
                    XMLHttpRequest.setRequestHeader("SOAPAction", "");
                },
                success: function (data) {
                    let ele = data.getElementsByTagName("return")[0];
                    document.getElementById('response').innerHTML = ele.childNodes[0].childNodes[0].data + ele.childNodes[1].childNodes[0].data;
                    // console.log(ele.childNodes[0].childNodes[0].data);
                    // alert(ele.childNodes[1].childNodes[0].data);
                    // console.log(JSON.parse(ele.childNodes[0].data).age);
                    // alert(JSON.parse(ele.childNodes[0].data).name);
                }
                // error: function (data) {
                //     console.log(data);
                // }
            });
        }

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值