ajax调用webservice接口(ajax调用接口实例)
Web service是一个平台独立的,低耦合的,自包含的、基于可编程的web的应用程序,可使用开放的XML(标准通用标记语言下的一个子集)标准来描述、发布、发现、协调和配置这些应用程序,用于开发分布式的互操作的应用程序。
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:*,此设置表示允许所有外部请求调用,你也可以将*设置为具体的访问地址。
好了,搞定了,尽情的使用吧。