手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >基于JQuery的访问WebService的代码(可访问Java[Xfire])
基于JQuery的访问WebService的代码(可访问Java[Xfire])
摘要:我仔细看看了看看几个人的例子,发现了问题。众所周知WebService是遵守SOAP协议的,为什么例子都是JSON格式的参数传递?netWe...

我仔细看看了看看几个人的例子,发现了问题。众所周知WebService是遵守SOAP协议的,为什么例子都是JSON格式的参数传递?net WebService兼容JSON格式,而Java的是标准WebService,不兼容JSON。看来net害了大家啊。于是我仔细了解了WSDL文件,做了个例子。下面只放关键代码。

复制代码 代码如下:

$(function () {

$("#btnWs").click(btnAjaxPost);

});

function btnAjaxPost(event) {

$.ajax({

type: "POST",

contentType:"text/xml",

url:"http://*****/WebServiceTest/services/HelloWorldService",

data:getPostData(),//这里不该用JSON格式

dataType:'xml',//这里设成XML或者不设。设成JSON格式会让返回值变成NULL

success: function(xml) {

//对结果做XML解析。

//浏览器判断 (IE和非IE完全不同)

if($.browser.msie){

$("#result").append(xml.getElementsByTagName("ns1:out")[0].childNodes[0].nodeValue+"<br/>");

}

else{

$(xml).find("out").each(function(){

$("#result").append($(this).text()+"<br/>");

})

}

},

error: function(x, e) {

alert('error:'+x.responseText);

},

complete: function(x) {

//alert('complete:'+x.responseText);

}

});

}

//定义满足SOAP协议的参数。

function getPostData()

{

//根据WSDL分析sayHelloWorld是方法名,parameters是传入参数名

var postdata="<?xml version="1.0" encoding="utf-8"?>";

postdata+="<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">";

postdata+="<soap:Body><sayHelloWorld xmlns="http://tempuri.org/">";

postdata+="<parameters>"+$("#txtName").val()+"</parameters>";

postdata+="</sayHelloWorld></soap:Body>";

postdata+="</soap:Envelope>";

return postdata;

}

完整例子SVN地址:http://theyounglearningmaterials.googlecode.com/svn/trunk/JavaWebServices/WebServiceTest/

我以后所有学习的例子都会放在 http://theyounglearningmaterials.googlecode.com/svn/trunk/里面,方便管理防止丢失。

【基于JQuery的访问WebService的代码(可访问Java[Xfire])】相关文章:

javascript瀑布流式图片懒加载实例解析与优化

对联广告 可关闭

JavaScript中的Math.LOG2E属性使用详解

JavaScript中Cookies的相关使用教程

JavaScript中的substr()方法使用详解

jQuery插件datepicker 日期连续选择

Javascript客户端脚本的设计和应用

nextSibling

详解AngularJS中的表格使用

AngularJS学习笔记之基本指令

精品推荐
分类导航