WebService服务接口会生成一个标准的wsdl文件,或者访问一个URL地址可以查看WSDL信息。
WSDL:(Web服务描述语言,Web Services Description Language)是为描述Web服务发布的XML格式。
一般情况下,都是在客户端进行调用服务端暴露出来的接口,那么如何在浏览器中通过ajax的方式调用呢?var data = ‘<soap:Envelope xmlns:soap=”http://schemas.xmlsoap.org/soap/envelope/”>’+ ‘<soap:Header/>’+ ‘<soap:Body>’+ ‘<ns1:hello xmlns:ns1=”http://impl.server.ws.computech.com/”></ns1:hello>’+ ‘</soap:Body>’+ ‘</soap:Envelope>’;$.ajax({“type”: “POST”,“async”: false,“Content-Type”: “text/xml;charset=utf-8”,“url”: “http://192.168.1.60:8080/yourApp/service/cmp”,“dataType”: “xml”,“data”: data,“success”: function(response){console.log(“success”);},“error”: function(e){console.log(“error”);}});SOAP:简单对象访问协议是交换数据的一种协议规范,是一种轻量的、简单的、基于XML(标准通用标记语言下的一个子集)的协议,它被设计成在WEB上交换结构化的和固化的信息。
其实基于soap协议的webservice服务,它传输的消息是被soap进行了一层包装,我们在进行post请求的时候,只要把完整的进行过soap包装的消息发送出去就可以了。
如果此时,你就立即进行调用测试,浏览器调试控制台会报错:No ‘Access-Control-Allow-Origin’ header is present on the requested resource.因为webservice是一种跨平台服务,因此在浏览器中使用就涉及到跨域的问题。
为了解决此问题,你需要在暴露webservice服务的服务端进行一些设置。
在服务器返回给你的响应消息头中,需要增加一下设置:Access-Control-Allow-Origin:*,此设置表示允许所有外部请求调用,你也可以将*设置为具体的访问地址。
好了,搞定了,尽情的使用吧。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)