怎样在JavaScript中调用WebService获取数据_刘锦伟

合集下载

调用webservice的几种方式

调用webservice的几种方式

调用webservice的几种方式webservice是一种服务,它可以让不同类型的应用程序通过网络交换数据和信息,通过联网,客户可以与服务器端通信,而服务器端可以生成一些特定的网络服务。

webservice使得手机端客户可以实时调用服务器端的接口,从而获取相应的资源和信息,也就是说客户和服务器端之间的计算机网络协议可以实现webservice方式的交互。

通常情况下,webservice有几种不同的实现方式。

下面简单介绍几种可以实现webservice的方式。

1. 使用Axios或低层Javascript原生api发起HTTP请求。

Axios是一个支持浏览器和node.js的客户端框架,用来发起http请求。

它可以实现前后端数据交互,实现webservice。

2. 使用传统soap协议发起HTTP请求。

soap(simple object access protocol)是一种基于XML的协议,它可以通过HTTP使得应用程序交互,它可以使用简单的消息来交互数据,而不用编写特定的代码。

3. 使用REST协议发起HTTP请求。

REST协议是一种使用RESTful API的软件设计架构,它是用来构建及交互分布式系统的一种设计方法。

4. 使用JSON API发起HTTP请求。

JSON API是一种用以支持数据并行关系的API,可以让JSON数据分发,并且提供资源定位、数据多态、查询、及内容引用等功能,从而构建实现交互的webservice系统。

5. 使用gRPC发送HTTP请求。

gRPC是一种开放源的远程过程调用(RPC)系统,可以通过http2发起请求。

它的实现允许你在任何语言之间实现客户端/服务器端通信,以及实现webservice功能。

以上就是实现web service的几种方式,它们可以帮助我们将不同的应用程序通过网络交换数据和信息,实现webservice的功能,它可以帮助我们更好地构建客户端/服务器端通信环境,让客户可以实时调用服务器端接口,实现我们想要的功能,方便地实现我们服务器与客户端之间的交互和通信。

使用javascript调用webservice示例

使用javascript调用webservice示例

使用javascript调用webservice示例再javascript中使用soap调用webservice的示例代码代码再IE6和FF测试通过,对于c#写的webservice和java(xfire)写的,都测试过,没有问题此代码原型来源于/的javascript soapclient发现这个下载的js只能用于调用c#的webservice,所以利用mootools,重新封装,达到IE和火狐的兼容的同时,兼容java和c#(再例子中使用的mootools.v1.11.js 文件,做过修改)客户端js调用代码如下js 代码1.function ajaxRequest()2. {3.var url ="http://localhost:88/webservicedemo.asmx";4.5.//设置webService传入参数6.//7.//注意:8.//9.// 调用.Net 写的webservice(如例子中的webservicedemo.asmx)10. // HelloTo(Stringname) 针对name参数必须写成 wqj,还有更多参数一样写,使用名称匹配11. // 传入的参数数量可以不等于(多于或少于)方法要求的参数12. //13. // 调用java(xfire) 发布的webService14. // 传入的参数必须与调用方法的参数数量相等,且按传入值的顺序进行匹配15. //16.17. var para = "wqj"; 这里应该是一个标准的xml形式,源码贴出来时被虑掉了,请参看附件源码18.19. var op = {20. data:para,21. onComplete:showResponse,22. onFailure:showError,23. update:'ajaxBack'24. };25.26. var service = newWebService(url,"HelloTo",op);27. service.request();28. return false;29. }30. function showError(obj)31. {32. //obj 是一个xmlHttpRequest对象33. alert("error");34. }35. function showResponse(requestText,requestXML)36. {37. //requestText 返回的文本38. //requestXML 返回的XML39. alert("ok");40. }WebService类的代码如下(webservice.js)js 代码1.var WSDLS = {};2.3.var WebService = new Class({4.5. url : '',6. method : '',7. options:8. {9. method:'GET',10. data: null,11. update: null,12. onComplete: Class.empty,13. onError:Class.empty,14. evalScripts: false,15. evalResponse: false16. },17.18. initialize: function(url,method,options)19. {20. this.url = url;21. this.method = method;22. this.options = options;23.24. },25.26. request : function()27. {28. var wsdl = WSDLS[this.url];29. if(!wsdl)30. {31. var op = {method:'GET',async:false};32. var wsdlAjax = new XHR(op).send(this.url+ "?wsdl", null);33. wsdl =wsdlAjax.transport.responseXML;34. WSDLS[this.url] = wsdl;35. }36. this.setSoap(wsdl);37. },38.39. setSoap : function(wsdl)40. {41.42. var ns =(wsdl.documentElement.attributes["targetNamespace"] + "" =="undefined") ?wsdl.documentElement.attributes.getNamedItem("targetNamespace") .nodeValue :wsdl.documentElement.attributes["targetNamespace"].value;43. var sr =44. "" +45. ""46. "xmlns:xsi=\"/2001/XMLSchema-instance\" " +47. "xmlns:xsd=\"/2001/XMLSchema\" " +48. "xmlns:soap=\"http://schemas.xm/soap/envelope/\">" +49. "" +50. "<"+ this.method + " xmlns=\""+ns + "\">" +51. (this.options.data=== null ?"":this.options.data) +52. " + this.method + ">;53.54. this.options.method = 'post';55. this.options.data = null;56.57. var soapaction = ((stIndexOf("/") !=ns.length - 1) ? ns + "/" : ns) + this.method;58.59. var soapAjax = newAjax(this.url,this.options);60. soapAjax.setHeader("SOAPAction",soapaction);61. soapAjax.setHeader("Content-type", "text/xml;charset=utf-8");62. soapAjax.request(sr);63. }64.65.});在第一个版本中存在以下问题1. 不能根据webservice的要求输入参数自动组织参数2. 没有处理返回值3.一旦webservice调用过程出错,会形成一个死循环(一直弹出error)V2 说明1. 解决第一版中死循环的问题2. 统一输入参数的传入形式(与mootools的ajax使用方式完全一致),形式如name=wqj&age=20&........3. 自动根据参数名对应的值,组织webservice的传入参数,只根据webservice 要求的参数名查找对应的值与顺序不再有关系.(对于xfire中的输入参数使用名称in0,in1........)传入的参数数量也不再要求一致,多的自动丢弃,少的自动传空4. 对于返回的XML,增加提取方法,返回需要的关键返回值(去掉XML的框框)详细参照附件源码,下面是部分关键代码••JavaScriptSOAP.rar (47.1 KB)•描述: js调用webservice示例•下载次数: 443•JavaScriptSOAP(V2).rar (49.5 KB)•描述: js,sope第二版•下载次数: 761引用地址:/topic/98182代码再IE6和FF测试通过,对于c#写的webservice和java(xfire)写的,都测试过,没有问题此代码原型来源于/的javascript soapclient发现这个下载的js只能用于调用c#的webservice,所以利用mootools,重新封装,达到IE和火狐的兼容的同时,兼容java和c#(再例子中使用的 mootools.v1.11.js 文件,做过修改)客户端js调用代码如下js 代码1.function ajaxRequest()2.{3.var url = "http://localhost:88/webservicedemo.asmx";4.5.//设置webService传入参数6.//7.//注意:8.//9.// 调用.Net 写的webservice(如例子中的webservicedemo.asmx)10. // HelloTo(String name)针对name参数必须写成<name></name>wqj,还有更多参数一样写,使用名称匹配11. // 传入的参数数量可以不等于(多于或少于)方法要求的参数12. //13. // 调用java(xfire) 发布的webService14. // 传入的参数必须与调用方法的参数数量相等,且按传入值的顺序进行匹配15. //16.17. var para = "<name></name>wqj"; 这里应该是一个标准的xml形式,源码贴出来时被虑掉了,请参看附件源码18.19. var op = {20. data:para,21. onComplete: showResponse,22. onFailure:showError,23. update:'ajaxBack'24. };25.26. var service = new WebService(url,"HelloTo",op);27. service.request();28. return false;29. }30. function showError(obj)31. {32. //obj 是一个xmlHttpRequest对象33. alert("error");34. }35. function showResponse(requestText,requestXML)36. {37. //requestText 返回的文本38. //requestXML 返回的XML39. alert("ok");40. }WebService类的代码如下(webservice.js)js 代码1.2.var WSDLS = {};3.4.var WebService = new Class({5.6.url : '',7.method : '',8.options:9.{10. method:'GET',11. data: null,12. update: null,13. onComplete: Class.empty,14. onError:Class.empty,15. evalScripts: false,16. evalResponse: false17. },18.19. initialize: function(url,method,options)20. {21. this.url = url;22. this.method = method;23. this.options = options;24.25. },26.27. request : function()28. {29. var wsdl = WSDLS[this.url];30. if(!wsdl)31. {32. var op = {method:'GET',async: false};33. var wsdlAjax = new XHR(op).send(this.url + "?wsdl", null);34. wsdl = wsdlAjax.transport.responseXML;35. WSDLS[this.url] = wsdl;36. }37. this.setSoap(wsdl);38. },39.40. setSoap : function(wsdl)41. {42.43. var ns = (wsdl.documentElement.attributes["targetNamespace"] + "" == "undefined") ? wsdl.documentElem ent.attributes.getNamedItem("targetNamespace").nodeValue : ws dl.documentElement.attributes["targetNamespace"].value;44. var sr =45. "" +46. ""47. "xmlns:xsi=\"/2001/XMLSchema-instance\" " +48. "xmlns:xsd=\"/2001/XMLSchema\" " +49. "xmlns:soap=\"http://schemas.xm/soap/envelope/\">" +50. "<soap:body>"</soap:body> +51. "<" + this.method + " xmlns=\"" + ns + "\">" +52. (this.options.data === null ?"":this.options.data) +53. " + this.method + ">;54.55. this.options.method = 'post';56. this.options.data = null;57.58. var soapaction = ((stIndexOf("/") !=ns.length - 1) ? ns + "/" : ns) + this.method;59.60. var soapAjax = new Ajax(this.url,this.options);61. soapAjax.setHeader("SOAPAction", soapaction);62. soapAjax.setHeader("Content-type", "text/xml;charset=utf-8");63. soapAjax.request(sr);65.66.});在第一个版本中存在以下问题1. 不能根据webservice的要求输入参数自动组织参数2. 没有处理返回值3.一旦webservice调用过程出错,会形成一个死循环(一直弹出error)V2 说明1. 解决第一版中死循环的问题2. 统一输入参数的传入形式(与mootools的ajax使用方式完全一致),形式如name=wqj&age=20&........3. 自动根据参数名对应的值,组织webservice的传入参数,只根据webservice 要求的参数名查找对应的值与顺序不再有关系.(对于xfire中的输入参数使用名称in0,in1........)传入的参数数量也不再要求一致,多的自动丢弃,少的自动传空4. 对于返回的XML,增加提取方法,返回需要的关键返回值(去掉XML的框框)详细参照附件源码,下面是部分关键代码WebService类的代码如下(webservice.js)js 代码1.var WSDLS = {};2.3.var WebService = new Class({4.5.url : '',6.method : '',7.options:9.method:'GET',10. data: null,11. update: null,12. onComplete: Class.empty,13. onError:Class.empty,14. evalScripts: false,15. evalResponse: false16. },17.18. initialize: function(url,method,options)19. {20. this.url = url;21. this.method = method;22. this.options = options;23. },24.25. request : function()26. {27. var wsdl = WSDLS[this.url];28. if(!wsdl)29. {30. var op = {method:'GET',async: false};31. var wsdlAjax = new XHR(op).send(this.url + "?wsdl", null);32. wsdl = wsdlAjax.transport.responseXML;33. WSDLS[this.url] = wsdl;34. }35.36. this.setSoap(wsdl);37. },38.39. setSoap : function(wsdl)40. {41. var paraXML = this.getParaXML(wsdl);42. alert(paraXML);43. var ns = (wsdl.documentElement.attributes["targetNamespace"] + "" == "undefined") ? wsdl.documentElem ent.attributes.getNamedItem("targetNamespace").nodeValue : ws dl.documentElement.attributes["targetNamespace"].value;44. var sr =45. "" +46. " +47. "xmlns:xsi=\"/2001/XMLSchema-instance\" " +48. "xmlns:xsd=\"/2001/XMLSchema\" " +49. "xmlns:soap=\"http://schemas.xm/soap/envelope/\">" +50. "<soap:body>"</soap:body> +51. "<" + this.method + " xmlns=\"" + ns + "\">" +52. paraXML +53. " + this.method + ">";54.55. this.options.method = 'post';56. this.options.data = null;57.58. var soapaction = ((stIndexOf("/") !=ns.length - 1) ? ns + "/" : ns) + this.method;59.60. var soapAjax = new Ajax(this.url,this.options);61. soapAjax.setHeader("SOAPAction", soapaction);62. soapAjax.setHeader("Content-type", "text/xml;charset=utf-8");63. soapAjax.request(sr);64. },65. getParaXML : function(wsdl)66. {67.68. var objNode = null;69. var rtnValue = "";70. //java(xfire)71. var ell = this.getElementsByTagName(wsdl,"xsd:element");72. if(ell.length == 0)73. {74. //c#75. ell = this.getElementsByTagName(wsdl,"s:element");76. }77. for(var i = 0; i < ell.length; i++)78. {79. if(this.getElementAttrValue(ell[i],"name") == this.method)80. {81. objNode = ell[i];82. break;83. }84. }85.86. if(objNode == null) return rtnValue;87. //java(xfire)88. ell = this.getElementsByTagName(objNode,"xsd:element");89. if(ell.length == 0)90. {91. //c#92. ell = this.getElementsByTagName(objNode,"s:element");93. }94. if(ell.length == 0) return rtnValue ;95.96. var hash = new Hash();97.98. if(this.options.data != null && this.options.data.clean != "")99. {100.hash = this.options.data.split("&").toHash("=");101.}102.103.for(var i = 0; i < ell.length; i++)104.{105.var paraName = this.getElementA ttrValue(ell[i],"name");106.rtnValue = rtnValue + this.get SingleXML(paraName,hash);107.}108.109.return rtnValue;110.},111.112.getSingleXML : function (name,hash)113.{ = name.trim();116.var rtnValue = "";117.if(hash.hasKey(name))118.{119.rtnValue = hash.get(name); 120.}121.rtnValue = "<" + name + ">" + xmls cc(rtnValue) + " + name + ">"122.return rtnValue;123.},124.getBackData: function(xml)125.{126.var rtnValue = "";127.//java(xfire)128.var soap = this.getElementsByTagName(xm l,"ns1:out");129.if(soap.length == 0)130.{131.//c#132.soap = this.getElementsByTagName (xml,this.method + "Result");133.}134.return soap[0].childNodes[0].nodeValue;135.136.},137.getElementsByTagName : function(objNode,tagName)138.{139.//tagName 形式如xsd:element ,写出tag的全称140.141.var ell;142.if(this.isIE())143.{144.ell = objNode.getElementsByTagNa me(tagName);145.}146.else147.{148.if(tagName.contains(":")) tagName = tagName.split(":")[1];149.ell = objNode.getElementsByTagNa me(tagName);151.return ell;152.},153.getElementAttrValue : function(objNode,attrName)154.{155.var rtnValue = "";156.157.if(objNode == null) return rtnValue;158.159.if(objNode.attributes[attrName] + "" == "undefined")160.{161.if(objNode.attributes.getNamedItem (attrName) != null)162.rtnValue = objNode.attri butes.getNamedItem(attrName).nodeValue ;163.164.}165.else166.{167.if(objNode.attributes[attrName] != null)168.rtnValue = objNode.attri butes[attrName].value;169.}170.return rtnValue;171.},172.isIE : function()173.{174.var isMSIE = /*@cc_on!@*/false;175.return isMSIE;176.}177.});178.179.Array.extend({180.181.toHash : function (splitChar)182.{183.var hash = new Hash({});184.for(var i=0;i<this.length;i++)185.{186.187.if(this[i].split(splitChar).length == 1) contrnue;188.189.var key = this[i].split(splitCh ar)[0].trim();190.var value = this[i].split(split Char)[1].trim();191.192.hash.set(key, value);193.}194.195.return hash;196.}197.});198.199.function xmlscc(strData)200.{201.202.strData=strData.replace(/&/g, "&");203.strData=strData.replace(/>/g, ">");204.strData=strData.replace(/"<");205.strData=strData.replace(/"/g, """);206.strData=strData.replace(/'/g, "'");207.return strData;208.}相应的调用代码如下:js 代码1.<script type=< span="">"text/javascript">2.3.var service ;4.function ajaxRequest()5.{6.var url = "http://localhost:88/webservicedemo.asmx";7.8.//设置webService传入参数9.//10. //注意:11. //12. // 调用webservice(如例子中的webservicedemo.asmx)13. // HelloTo(String name)针对name参数必须写成name=wqj ,还有更多参数一样写,使用&符号分隔(name=11&age=20&.....),使用名称匹配14. // 传入的参数数量可以不等于(多于或少于)方法要求的参数15.16.17. var para = "name=wqj";18.19. var op = {20. data:para,21. onComplete: showResponse,22. onFailure:showError,23. update:'ajaxBack'24. };25.26. service = new WebService(url,"HelloTo",op);27. service.request();28. return false;29. }30. function showError(obj)31. {32. //obj 是一个xmlHttpRequest对象33. alert("error");34. }35. function showResponse(requestText,requestXML)36. {37. //requestText 返回的文本38. //requestXML 返回的XML39. // service.getBackData 就是取出返回的XML中,实际需要的数据40. //经过测试兼容IE,FF41. alert(service.getBackData(requestXML));42.43. }44. </script>。

webservice调用方法

webservice调用方法

webservice调用方法
service是一项用于搜集、处理、分发和存储基于云的数据服务。

它能够提供准确、及时、高效和安全的数据获取能力,将海量数据信息变成可用的数据资源。

service可以为用户提供数据安全、可靠、及时服务。

service调用方法具有不同的实施方式,具体取决于所采用的数据源。

首先,用户需要根据需求确定需要采集的数据源,然后完成数据源注册、配置访问权限等。

在这个过程中,用户需要区分内部和外部访问,并为每种访问方式分配相应的权限。

一旦配置完成,用户可以使用标准协议或自定义API调用service接口完成数据采集。

首先,用户需要根据需求确定采集数据的范围,然后指定访问接口、参数,调用service接口即可实现数据的采集,并返回相应的结果。

此外,还可以使用技术和算法支持service对数据的动态处理,提高获取数据的准确率和效率。

例如,可以利用智能解析算法将原始数据格式转换成更容易处理的格式,然后进行检索、过滤等操作,将获取到的信息进行精炼,更加符合用户需求。

最后,service还可以提供自动分发和存储功能,可以将采集的数据以文件或消息的形式自动分发到指定的存储目标,并以定时任务或其他方式保持数据的更新。

总之,service调用方法实现了根据用户需求快速准确采集信息、动态处理数据、自动分发和存储的功能,使用户能够快速、及时、高
效地获取需要的信息。

#jQuery使用Ajax方法调用WebService

#jQuery使用Ajax方法调用WebService

jQuery使用Ajax方法调用WebService 在这里将jQuery使用Ajax 调用WebService 的几个常用的方法做了一个整理,提供给正在找这方面内容的博友,希望能给学习jQuery的朋友一点帮助。

代码直接复制即可。

ws.aspx 代码<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0Transitional//EN" ""><html xmlns=""><head id="Head1" runat="server"><title></title><script src="jquery.js"type="text/javascript"></script><style type="text/css">.hover{cursor: pointer。

/*小手*/background: #ffc。

/*背景*/ }.button{width: 150px。

float: left。

text-align: center。

margin: 10px。

padding: 10px。

border: 1px solid #888。

}#dictionary{text-align: center。

font-size: 18px。

clear: both。

border-top: 3px solid #888。

}#loading{border: 1px #000 solid。

background-color: #eee。

padding: 20px。

margin: 100px 0 0 200px。

position: absolute。

js调用webservice方法

js调用webservice方法

js调用webservice方法随着Web应用程序的日益普及,越来越多的应用场景需要前端JS 与后端webservice进行交互,而JS调用webservice方法已成为了一种高效方便的方法。

下面我们就详细介绍一下如何进行JS调用webservice方法。

一、什么是webservice?我们想要调用webservice方法,首先需要了解什么是webservice。

Webservice是一种基于网络的应用程序,它是一组远程方法调用的集合,可以跨越各种网络和操作系统平台进行交流。

我们可以用webservice将两个应用程序集成到一个完整的解决方案中,互相交互和传递数据。

二、JS调用webservice的实现JS调用webservice方法的实现主要分为以下两步:1、编写webservice接口:需要使用C#或Java等语言编写webservice的服务端程序,暴露对外的接口。

2、调用webservice接口:在JS中编写代码,通过AJAX的方式调用服务端webservice接口进行远程调用,从而实现数据的传输和交互。

三、具体实现步骤1、编写webservice接口代码:在这里,我们以C#为例来说明如何编写webservice的服务端代码,具体流程如下:① 创建一个Web应用程序项目,选择C#语言,命名为“WebServiceTest”;② 在解决方案中添加一个web service的项,命名为“DemoWebService.asmx”,该项会自动生成代码文件;③ 接着在代码文件中添加需要公开的方法,例如以下代码:[WebMethod]public string GetStr(string name){return "Hello! " + name + " is calling me.";}到这里,服务端的webservice接口就编写完毕了。

2、在JS中调用webservice接口:在编写JS代码时,主要通过AJAX的方式进行调用,流程如下:① 创建一个XMLHttpRequest对象,通过该对象来产生异步请求,例如以下代码:var xmlhttp = null;if (window.XMLHttpRequest){xmlhttp=new XMLHttpRequest();}else{xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}② 创建请求地址和参数,例如以下代码:var url ="http://localhost/WebServiceTest/DemoWebService.asmx/GetStr"; var data = "name=" + encodeURIComponent("Tom");③ 配置请求头信息和请求体内容,例如以下代码:xmlhttp.open("POST", url, true);xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded; charset=utf-8");xmlhttp.send(data);④用xmlhttp对象的onreadystatechange方法来检测服务器返回结果,获取调用结果的返回值,例如以下代码:xmlhttp.onreadystatechange = function() {if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {var result = xmlhttp.responseText;alert(result);}}如此一来,JS调用webservice的流程就完成了。

webservice接口调用方法

webservice接口调用方法

webservice接口调用方法Web服务(Web service)是指一个网络服务,通过互联网进行通信的应用程序接口(API),使用标准的HTTP协议进行数据传输和交互。

它使用SOAP(Simple Object Access Protocol)来封装数据,以XML格式进行传递,可以在多种平台上进行调用,独立于编程语言和操作系统。

调用Web服务的方法如下:1.确定服务地址和方法:首先要确定要调用的Web服务的地址和要调用的方法。

通常,服务地址是一个URL(Uniform Resource Locator),可以在文档中找到。

2.创建SOAP请求:根据要调用的方法创建一个SOAP请求。

SOAP 请求是一个XML文档,根据服务的定义,包含要调用的方法名和方法参数。

可以使用各种编程语言和工具来创建SOAP请求,如Java的JAX-WS、Python的suds等。

3.发送请求:将创建的SOAP请求发送给Web服务。

可以使用HTTP POST或其他协议将请求发送给服务的URL。

请求与服务之间的通信是通过HTTP协议完成的。

4.解析响应:接收到Web服务的响应后,需要解析响应的内容。

响应是一个XML文档,包含服务返回的数据。

同样,可以使用各种编程语言和工具来解析XML响应,提取所需的数据。

5.处理响应:根据需要处理响应的数据。

可以将数据保存到数据库中,显示在用户界面上,或者进行其他操作。

6.处理错误:如果在调用Web服务时发生错误,需要处理错误。

可能会遇到网络连接问题、服务不可用、权限问题等。

根据错误类型,可以采取不同的处理方式,如重试请求、记录错误信息等。

7.错误处理:同样重要的是处理错误。

如果在调用Web服务时发生错误,需要处理错误。

可能会遇到网络连接问题、服务不可用、权限问题等。

根据错误类型,可以采取不同的处理方式,如重试请求、记录错误信息等。

8.安全性:在调用Web服务时,需要确保数据的安全性。

可以使用加密和数字签名等技术来保护传输的数据。

JavaScript调用WebService的方法

JavaScript调用WebService的方法

JavaScript调用WebService的方法一、带参数的方法<script type ="text/javascript" >function PostRequestData(URL, data){var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");xmlhttp.Open("POST", URL, false);xmlhttp.SetRequestHeader("Content-Type", "text/xml; charset=utf-8");xmlhttp.SetRequestHeader("SOAPAction", "");xmlhttp.setRequestHeader("Content-Length", data.length);try{xmlhttp.Send(data);var result = xmlhttp.status;}catch(ex){return("0" + ex.description + "|" + ex.number);}if (result == 200){return(xmlhttp.responseT ext);}xmlhttp = null;}function ServiceCall(){var r;var data;var url = 'http://localhost:2119/js%E8%B0%83%E7%94%A8Webservice/S ervice1.asmx';data = "<?xml version='1.0' encoding='utf-8'?>";data = data + '<soap:Envelope xmlns:xsi="" xmlns:xsd="" xmlns:soap="/soap/envelope/">';data = data + "<soap:Body>";data = data + '<HelloWorld xmlns="" />';data = data + "</soap:Body>";data = data + "</soap:Envelope>";r = PostRequestData(url, data);document.getElementById("data").innerHTML = r;}</script>二、带参数的方法function PostRequestData(URL, data){var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");xmlhttp.Open("POST", URL, false);xmlhttp.SetRequestHeader("Content-Type", "application/x-www-form-urlencoded");xmlhttp.setRequestHeader("Content-Length", data.length);try{xmlhttp.Send(data);var result = xmlhttp.status;}catch(ex){return("0" + ex.description + "|" + ex.number);}if (result == 200){return(xmlhttp.responseT ext);}xmlhttp = null;}function ServiceCall(a,b){var r;var data;var url = 'http://localhost:2119/js%E8%B0%83%E7%94%A8Webservice/S ervice1.asmx/Add';data = "a="+a+"&b="+b;r = PostRequestData(url, data);document.getElementById("data").innerHTML = r;}</script>。

WebService服务调用方法介绍

WebService服务调用方法介绍

WebService服务调用方法介绍WebService是一种基于网络的互操作技术,可通过简单对象访问协议 (SOAP) 来实现不同平台和编程语言之间的通信。

WebService服务调用方法是指通过客户端应用程序与后端WebService进行通信,实现数据传输和功能调用的过程。

下面将详细介绍WebService服务调用方法。

1. 了解WebService服务:在使用WebService服务之前,首先需要了解所需要调用的WebService服务的接口、方法以及参数。

通常,WebService会提供一个WSDL(Web Services Description Language)文件,其中定义了WebService的接口和方法信息。

通过WSDL文件,客户端可以获取到所有WebService接口的详细描述和相关信息。

2. 创建客户端应用程序:为了调用WebService服务,需要创建一个客户端应用程序。

这可以是一个使用特定编程语言编写的应用程序,如Java、C#等。

在客户端应用程序中,需要导入和使用与WebService相关的库和类,以便在应用程序中调用WebService服务。

3. 创建服务代理:客户端应用程序需要创建一个用于与WebService 服务进行通信的代理。

代理是客户端应用程序与WebService服务之间的中间层,它用于封装与WebService的通信细节,并提供一种方便的方式来调用WebService服务的方法。

根据不同编程语言和框架的要求,可以通过使用类似“wsimport”或“svcutil”等工具来生成代理类。

4. 调用WebService服务方法:通过创建的代理类,客户端应用程序可以直接调用WebService服务的方法。

在调用方法之前,需要根据WebService服务的接口定义传递正确的参数。

参数的传递通常是通过创建请求对象并为其设置相应的属性来完成的。

请求对象将包含需要传输给WebService服务的数据。

常用调用webservice的方法

常用调用webservice的方法

常用调用webservice的方法全文共四篇示例,供读者参考第一篇示例:在现今的软件开发领域中,调用Webservice已经成为一种常见的做法。

Webservice是一种通过网络进行数据交换的技术,可以让应用程序在不同的机器之间进行通信,使得不同的系统可以共享数据和功能。

在本文中,我们将介绍一些常用的调用Webservice的方法以及一些注意事项。

## 一、SOAP协议SOAP(Simple Object Access Protocol)是一种通用的传输协议,可以通过HTTP进行数据交换。

在调用Webservice时,我们可以使用SOAP协议来进行数据交互。

通常情况下,我们可以使用SOAP客户端来发送SOAP请求并接收返回的SOAP响应。

```javaimport javax.xml.soap.*;import java.io.*;## 二、RESTful API```javaimport java.io.BufferedReader;import java.io.InputStreamReader;import .HttpURLConnection;import .URL;## 三、使用开源库除了手动编写代码来调用Webservice,我们还可以使用一些现成的开源库来简化这个过程。

Apache CXF是一个流行的Webservice框架,它提供了丰富的API和工具来帮助我们开发和调用Webservice。

HelloWorld client = (HelloWorld) factory.create();String result = client.sayHello("world");System.out.println(result);}}```## 四、安全注意事项在调用Webservice时,我们也需要考虑安全因素。

我们可以使用HTTPS来保护数据的传输安全,可以使用WS-Security来保护数据的机密性和完整性,还可以使用OAuth来进行身份验证和授权。

调用第三方webservice接口的流程

调用第三方webservice接口的流程

调用第三方webservice接口的流程调用第三方webservice接口是一种常见的,在不同平台和语言环境下,由不同的开发人员往来的行为。

目前,API提供方已经开发了各种语言的SDK或者封装好的API,方便使用者进行开发。

以下是调用第三方webservice接口的流程:1. 了解webservice接口的基本信息webservice接口的基本信息一般包括调用地址、接口方法、参数、数据格式等。

在使用webservice接口前,需要对这些基本信息进行了解。

2. 判断是否需要注册API密钥有些API需要注册API密钥,以获得调用授权,如果需要则应进行相关操作。

3. 选择开发语言和SDK由于不同的开发者可能有不同的开发语言和环境,需要选择相应的API开发语言和SDK。

一些API的供应商会提供针对特定语言的SDK。

4. 进行API文档阅读和熟悉操作流程API文档是使用API的前提条件,因此需要进行充分的阅读,了解API的依赖关系、返回结果、参数类型等。

掌握API文档后,需要根据文档中提供的操作流程进行开发。

5. 创建API调用对象使用SDK中提供的类库,创建API调用对象。

这意味着您可以使用一些通用的方法来建立API的请求并进行响应处理。

6. 请求API数据使用API调用对象向API接口发送请求,其中包含所有必要的参数信息。

在请求的同时,还应注意与API密钥的验证和身份认证等相关信息。

7. 处理API响应数据API调用对象接收并响应API返回的数据。

开发人员应根据API文档中提供的规范,对API返回数据进行适当的解析和处理。

8. 进行错误处理在API响应时,可能会出现各种错误,例如参数不正确、系统繁忙等。

开发者需要根据API文档中提供的错误码进行判断和处理。

9. 结束API调用最后,开发者需要调用API调用对象中的结束API方法以释放资源并结束API调用。

在以上流程中,开发者还需要不断地优化API调用的性能,提高数据获取的效率。

怎样在JavaScript中调用WebService获取数据_刘锦伟

怎样在JavaScript中调用WebService获取数据_刘锦伟
常 熟 悉 的 方 式 是 直 接 在 ASPX 页 面 中 编 写 代 码 , 或 者 在 CS 文
件中编写代码, 直接操作 的 服 务 器 端 控 件 属 性 , ASP.
NET AJAX 提供了一种额外的方法。
下 面 通 过 实 例 来 介 绍 如 何 在 JavaScript 中 调 用 WebService
DAA05 where DAA01.JH=DAA05.JH"; TestJSWebService.WS.getData (sqlstr, getdataCall-
back); } function getdataCallback(result) { var rows = eval("(" + result + ")"); if (rows == null) { alert("记录为空"); } else { var rcount = rows.count; //根据 ID 查找对象,
con.Open(); adapter.Fill(ds,"DataTables"); } finally { con.Close(); } return toJson(ds.Tables[0]); }
toJson () 函数将获得的 DataTable 对象转换成 JSON 格式的
字符串, 包括返回数据记录的总数及所有记录。 格式如下: {
Service 时应按照如下格式:
[NameSpace]. [ClassName]. [MethodName] (param1, param2 ..., callbackFunction);
其中 “callbackFunction” 为 回 调 函 数 名 称 , 该 回 调 函 数 将

怎样在JavaScript中调用WebService获取数据

怎样在JavaScript中调用WebService获取数据
N A 提 供 了一 种 额外 的方 法 。 ETAJ X
Id f(t!= n l&& d . wsCo n ul t Ro . u t> 0 ) ( J o Stig. p n ( ) s n r Ap e d“ n {¨ J o Stig. p n (“o n':十 d . wsCo n s n r Ap e d‘ c u t' n 、 , 。 tRo . u t+ “) .: “ J o S r gAp e d。 o s n ti . p n ( w 。 : n r : ㈢ f r( ti i d . wsCo n ;++ o i :0 < tRo u t i ) n
{ S r g i e s n tig : n w tigB i e O ti Bul rJ o S r n d n e Sr n ul r ; d
在 实 际 开 发 工 作 中 ,要 求 在 J v S r t 获 取 We S r a a i 中 p b . v e 回 的数 据 集 .更 新 页 面 中 H M i 返 c T L控 件 的 属 性 或 内容 。通 常 熟 悉 的 方 式 是 直 接 在 A P 页 面 中编 写 代 码 , 或 者 存 C SX S文 件 中编 写 代 码 ,直 接 操 作 A PN t 服 务 器端 控 件 属 性 ,A P S .e 的 S.
/ < a a n me “t / p rm a = d ” a a a l  ̄ < p rm> >D tT b e类 /aa / <eun > S / rt r s J ON格 式 字 符 串 , 包括 记 录 数 c u t记 录 o n,
/rws /e u > /o < r t ms p iae s r g t J o ( t T be d) r t ti 0 s nDaa a I t v n

利用JavaScript来访问WebService来操作服务器数据库 - 冷风

利用JavaScript来访问WebService来操作服务器数据库 - 冷风
t d G tX l()
1/5
2009-1-14
2005年7月 (1) 2005年5月 (1) 2005年3月 (6) 2005年2月 (3) 2005年1月 (5) 2004年12月 (2) 2004年10月 (2)
相册 去農場 我的家庭
最新随笔 1. 假如現在讓你去說服客戶使 用2.0開發系統,你會 怎麼說服呢? 2. 對象化javascript日期控件 3. 工作排程 4. 防止圖片在WEB頁面上下載 5. 今天從新整理的大小寫數據 轉換 6. 常用的XPATH說明 7. XmlHttp在DoNet中的完全 应用---前/后台完成分离篇 8. 系统用户权限与角色分析 9. 学习设计模式之Composite 模式 10. 改進Richer的WEB頁面進 度條!
var s; s=""; nodeList =doc Submit .doc ument Element .get Element sByT agName("T able"); for (i=0;i<nodeList.length;i++) {
s=s + "<div style=\"WIDTH:490px;\" class=\"gotTitle\" onmouseover=\"javas cript:this.style.backgroundColor='lightblue'\" onmouseout=\"javascript:this.style.backgroundCol or='white'\" onclick=\"return gotTitle_onclick()\">&nbsp;" + nodeList(i).selectSingleNode("title"). text + "</div>";

调用webservice 方法

调用webservice 方法

调用webservice 方法随着信息技术的发展,越来越多的企业开始采用服务化架构,将自身的业务逐渐转化为Web服务的形式,以便于其他应用程序进行调用。

我们常常使用的webservice,就是一种基于XML、SOAP、WSDL协议的服务化架构,它提供了一种标准化的接口方式,用于不同平台之间的交互操作。

而调用webservice方法,则是这种交互操作的实现方式之一。

在使用webservice进行方法调用时,我们需要首先获取到需要调用的webservice的WSDL文件。

通过WSDL文件,我们可以获知webservice包含哪些方法、参数类型、返回值类型等相关信息。

接着,我们可以根据WSDL文件,生成对应的客户端代码,并通过客户端代码来进行方法调用。

在调用方法时,我们通常需要指定相应的输入参数,并对返回值进行处理。

当然,在实际的调用过程中,我们还需要考虑webservice的安全性、性能优化、错误处理等方面的问题。

如何保证webservice的安全性,防止恶意访问和攻击?如何优化webservice的性能,提高响应速度和稳定性?如何处理webservice调用异常,确保调用方能够及时处理错误信息?这些问题都需要我们在实践中实现和解决。

总的来说,调用webservice方法已经成为了企业应用开发中不可或缺的一部分。

通过webservice的服务化架构,我们可以方便地进行应用程序之间的交互操作,并实现各种数据的传输和共享。

因此,如果你是一名内容创作者,理解webservice调用的原理和方式,将对你的工作有着重要的意义。

javascript获取数据的方法

javascript获取数据的方法

javascript获取数据的方法JavaScript获取数据的方法:在使用JavaScript开发过程中,经常需要从外部数据源获取数据。

以下是一些常用的JavaScript获取数据的方法:1. AJAX请求:使用XMLHttpRequest对象可以通过发送异步请求获取数据。

通过open方法设置请求的方法(GET或POST)、URL和是否异步。

然后通过send方法发送请求。

可以通过onreadystatechange事件来监听请求的状态变化,并在请求完成时处理返回的数据。

2. Fetch API:Fetch API是一种新的网络请求接口,提供了更强大和灵活的功能。

使用fetch方法可以发送GET、POST等不同类型的请求,并使用Promise对象来处理响应。

可以设置请求的URL、请求头、请求体等参数,并通过then方法来处理返回的数据。

3. jQuery AJAX:如果您在项目中使用了jQuery库,可以使用其提供的AJAX方法来发送异步请求。

通过$.ajax方法可以设置请求的方法、URL、数据类型等参数,并通过success回调函数处理返回的数据。

4. JSONP:如果需要从跨域的服务器获取数据,可以使用JSONP方法。

JSONP是一种通过动态创建script标签来实现跨域请求的机制。

服务器返回的数据将被包裹在回调函数中,这样就可以在客户端中获取到数据。

5. WebSockets:如果需要实现实时通信,可以使用WebSocket。

WebSocket提供了双向通信的能力,可以在客户端和服务器之间进行实时交互。

通过创建WebSocket对象,可以建立与服务器的连接,并通过监听事件来处理接收到的数据。

这些方法都可以用于获取各种类型的数据,如JSON数据、文本数据、XML数据等。

根据不同的需求和场景,选择适合的方法可以更加高效地获取数据并进行处理。

记得在使用这些方法时,要考虑到数据安全性和错误处理机制。

js调用webservice方法

js调用webservice方法

js调用webservice方法1. 介绍Web服务是一种通过网络进行通信的跨平台应用程序接口(API)。

JavaScript是一门在客户端运行的脚本语言,可以通过调用Web服务的方法来实现与服务器之间的交互。

本文将深入探讨如何使用JavaScript调用Web服务的方法。

2. Web服务概述Web服务是一种通过Web协议进行通信的软件系统。

它通过使用标准的HTTP协议来提供互操作性和平台无关性,使不同平台上的应用程序能够相互通信。

Web服务通常使用XML(eXtensible Markup Language)来进行数据交换,可以在任何操作系统、编程语言和开发工具之间进行通信。

Web服务通常由两个主要组件组成:1.服务提供者:负责提供Web服务的服务器端应用程序。

它会将功能封装成可用的Web方法,并通过Web协议和通信协议进行暴露。

2.服务消费者:负责调用Web服务的客户端应用程序。

它会通过发送HTTP请求并接收HTTP响应来与服务提供者进行通信。

3. JavaScript调用Web服务的方法JavaScript通过HTTP请求实现与Web服务的通信。

它可以使用以下方法之一来调用Web服务:a. XMLHttpRequest对象XMLHttpRequest对象是JavaScript中的核心对象之一,用于在后台与服务器进行数据交换。

它能够实现异步数据传输,无需刷新整个页面。

调用Web服务的一般步骤如下:1.创建XMLHttpRequest对象。

var xhr = new XMLHttpRequest();2.设置请求方法和URL。

xhr.open('POST', ' true);3.设置请求头信息。

xhr.setRequestHeader('Content-Type', 'application/json');4.设置响应处理函数。

xhr.onload = function() {// 响应处理逻辑};5.发送请求并传递参数。

webservice调用具体方法

webservice调用具体方法

webservice调用具体方法摘要:1.什么是WebService2.如何调用WebService的具体方法3.调用过程中可能遇到的问题及解决方法4.实战案例分享正文:WebService,即网络服务,是一种跨平台的、基于XML(可扩展标记语言)的分布式计算技术。

它使得应用程序之间可以通过互联网进行通信,实现数据的交换和共享。

在实际开发中,调用WebService的具体方法如下:1.首先,确定你需要调用的WebService的地址和协议。

通常,WebService的地址是以WSDL(Web服务描述语言)文件形式提供的。

你可以通过WSDL文件查看WebService提供的接口和方法。

2.根据WSDL文件,生成客户端代码。

这可以通过使用诸如Apache CXF、JAX-WS等开源库来实现。

这些库会根据WSDL文件自动生成客户端代码,包括调用WebService的方法和处理响应的代码。

3.在生成的客户端代码中,找到调用WebService的具体方法。

这个方法通常是一个带有HTTP请求头的Web方法,如POST、GET等。

在方法中,传入所需的参数,这些参数通常包括在WSDL文件中定义的输入参数。

4.发送HTTP请求,并将响应结果解析为JSON、XML等格式。

这一步可以通过使用如Jackson、Gson等库来实现。

5.处理响应结果,并根据需要进行相应的业务逻辑处理。

在调用WebService的过程中,可能会遇到以下问题:1.网络问题:由于WebService通常跨网络调用,因此可能会遇到网络不稳定、延迟等问题。

为了解决这个问题,可以考虑使用重试策略、增加超时设置等方法。

2.服务异常:WebService可能会因为各种原因抛出异常,如参数不合法、服务器故障等。

为了解决这个问题,可以实现异常处理机制,如使用try-catch语句捕获异常,并根据需要进行日志记录、通知等操作。

3.身份验证和授权问题:为了避免unauthorized access,WebService 通常需要进行身份验证和授权。

WebService的方法

WebService的方法
几种调用WebService的方法2007-08-27 19:231. 在JavaScript中调用WebService
<script language="javascript">
function PostRequestData(URL,data){
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
2. 在Asp中
<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%>
<%
Dim strxml
Dim str
'定义soap消息
strxml = "<?xml version='1.0' encoding='tf-8'?>"
strxml = strxml & "<soap:Envelope xmlns:xsi='/2001/XMLSchema-instance' xmlns:xsd='/2001/XMLSchema' xmlns:soap='/soap/envelope/'>"
'初始化XML对象
'将手写的SOAP字符串转换为XML对象
' x.loadXML strxml
'初始化http对象
Set h = createobject( "Microsoft.XMLHTTP")
'向指定的URL发送Post消息

js webservice方法

js webservice方法

js webservice方法使用JavaScript编写WebService方法在Web开发中,JavaScript(简称JS)是一种常用的脚本语言,可以用于实现与Web服务器之间的数据交互。

通过使用WebService方法,我们可以在客户端使用JavaScript调用服务器上的函数,并接收返回的数据。

下面是一个示例代码,演示了如何使用JavaScript编写WebService方法。

首先,我们需要创建一个WebService文件,可以是一个包含服务器端代码的文件(如中的.asmx文件),也可以是一个API端点(如REST API)。

在这个文件中,我们可以定义需要被调用的函数和相应的参数。

```javascript// 示例WebService文件(webService.js)// 导出的函数将被JavaScript调用exports.calculateSum = function (a, b) {return a + b;};exports.getUserInfo = function (userId) {// 从数据库或其他数据源获取用户信息var user = {id: userId,name: "John Doe",age: 25return user;};```接下来,我们需要在客户端(如网页)上编写JavaScript代码,以调用服务器上的WebService方法,并处理返回的数据。

```javascript// 客户端JavaScript代码// 使用XMLHttpRequest对象发起HTTP请求var xhr = new XMLHttpRequest();// 指定HTTP请求的方法、URL和异步标志(此处假设WebService文件位于根目录下)xhr.open("GET", "/webService.js?method=getUserInfo&userId=123", true);// 定义请求完成时的回调函数xhr.onreadystatechange = function () {if (xhr.readyState == 4 && xhr.status == 200) {// 从服务器返回的响应中获取数据var response = JSON.parse(xhr.responseText);// 处理返回的数据console.log();console.log(response.age);};// 发送HTTP请求xhr.send();```在上述示例中,我们使用了XMLHttpRequest对象来发送HTTP请求,向服务器发起调用getUserInfo函数的请求,并传递了参数userId = 123。

从JavaScript中发送数据到WebService

从JavaScript中发送数据到WebService

JavaScript发送数据到WebService上一篇谈到从WebService获取数据到JavaScript,在js端可用DOM方式和jQuery对象方式来处理结果。

该篇我们来谈谈从JavaScript发送数据到WebService,重点强调两个方面1. 如何传递数据到WebService中2. 在WebService中如何接受数据,不同的接受形式如何处理从客户端传递数据到服务器,无外乎两种情况:其一,传递一个一个但个数据,比如:一个字符串,一个整数,或多个字符串变量其二,发送对象型数据,即在服务器端接受数据后需要构建一个或多个实体对象的情况以下用两个JavaScript函数分别来说明显示方式1.传递单个数据,js函数如下://传递一个字符串,可扩展到任何多个字符串$("#sendString").click(function () {$.post("WebServices/MyWebService.asmx/GetString",{ "str": "你好,大家好!" }, function (r) {alert($(r).text());});});WebService的GetString方法如下:[WebMethod]public bool GetString(string str) {//做个简单的运算,说明str接收到了数据return str.Length > 5;}2. 传递对象型数据。

在js不能构建C#的对象,要表示对象,在js中必须用JSON字符串,所以要传递对象或对象数组到服务器,只要传递JSON格式的字符串就可以了,如下面的方法,传递了两个User(针对服务器端而言)对象的数据到服务器端。

$("#sendJson").click(function () {$.ajax({type: "post",url: "WebServices/MyWebService.asmx/InputJsonObjects",data: '{"users": [{ "Id": "S001", "Name": "阿牛", "Age": 20 }, { "Id":"S002", "Name": "阿朱", "Age": 18}] }',dataType: "json",//必须是json,且不能缺少contentType: "application/json",//必须的success: function (result) {alert(result.d);},error: function (e) {alert(e.responseText);}});});WebService的InputJsonObjects方法如下:///<summary>///获得从客户端传来的Json格式的User对象信息///用数组直接接收///</summary>///<param name="users"></param>///<returns></returns>[WebMethod]public string InputJsonObjects(User[] users) {string name=null;if (users!=null && users.Length>0) {name = users[0].Name;//获得第一个对象的name属性值}return name;//向客户端一个name,证明服务器接收到数据了,没别意思,呵呵。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
器端控件, 并添加对上述服务的引用。
89
实用第一 智慧密集
<asp:ScriptManager ID="ScriptManager1" runat="server">
<Services> <asp:ServiceReference Path="WS.asmx" />
</Services> </asp:ScriptManager>
常 熟 悉 的 方 式 是 直 接 在 ASPX 页 面 中 编 写 代 码 , 或 者 在 CS 文
件中编写代码, 直接操作 的 服 务 器 端 控 件 属 性 , ASP.
NETቤተ መጻሕፍቲ ባይዱAJAX 提供了一种额外的方法。
下 面 通 过 实 例 来 介 绍 如 何 在 JavaScript 中 调 用 WebService
经 过 以 上 工 作 , 完 成 了 WebService 类 的 编 写 工 作 , 可 以
通过 “在浏览器中查看” 进行测试。 执行效果如图 1 所示。
完 成 WebService 类 的 编 写 后 , 再 编 写 aspx 页 面 部 分 。 首
先在默认的 “Default.aspx” 页面上添加一个 ScriptManager 服务
自 动 调 用 。 回 调 函 数 的result 参 数 代 表 了 本 次 异 步 调 用 的 返 回
结果, 即 WebService 方法的返回值。
页面 JavaScript 代码如下:
<script type="text/javascript"> function getdata() //获得数据 { document.all.Select1.options.length = 0; //传递 SQL 语句作为参数 var sqlstr = "select distinct QKDY from DAA01,
Service 时应按照如下格式:
[NameSpace]. [ClassName]. [MethodName] (param1, param2 ..., callbackFunction);
其中 “callbackFunction” 为 回 调 函 数 名 称 , 该 回 调 函 数 将
在服务器端异步调用成功返回后由 AJAX 异步通信层
DAA05 where DAA01.JH=DAA05.JH"; TestJSWebService.WS.getData (sqlstr, getdataCall-
back); } function getdataCallback(result) { var rows = eval("(" + result + ")"); if (rows == null) { alert("记录为空"); } else { var rcount = rows.count; //根据 ID 查找对象,
con.Open(); adapter.Fill(ds,"DataTables"); } finally { con.Close(); } return toJson(ds.Tables[0]); }
toJson () 函数将获得的 DataTable 对象转换成 JSON 格式的
字符串, 包括返回数据记录的总数及所有记录。 格式如下: {
为了区别于使用服务器端控件, 加入一个 HTML 控件,
<select id="Select1"> <option></option>
</select>
接 下 来 编 写 JavaScript 代 码 , 调 用 WebService 服 务 , 并 根
据返回的结果修改其选项值。 在客户端 JavaScript 中调用 Web-
// <param name="dt"> DataTable 类型</param> // <returns>JSON 格式字符串,包括记录数 count,记录 //rows</returns> private string toJson(DataTable dt) {
StringBuilder JsonString = new StringBuilder(); if (dt ! = null && dt.Rows.Count > 0) {
( ) ” 方 法 接 收 一 个 名 为 sqlstr 的 参 数 , 返 回 JSON 格 式 的 字
符串。
// <summary> // 获取一个数据集 // </summary> // <param name="cmd"> select 语句</param> // <returns>string 类型</returns> [WebMethod] public string getData(string cmd) {
" count" :记 录 总 数," rows" : [ { " 名 称" :" 值 1"} , { " 名
称" :" 值 2"}]}, 在 JavaScript 中 可 以 使 用 eval () 函 数 对 返 回
的 JSON 字符串进行处理。
// <summary> // 将 DataTable 转换成 JSON 格式字符串 // </summary>
} } } </script> 设置 body 的 onload=" getdata () ;", 运行程序 , 效果如图 2 所示。
至 此 , 完 成 了 使 用 JavaScript 调 用 WebService 的 全 部 过 程, 这里只是做了一个简单的演示, 可以根据开发过程中的实 际 需 要 编 写 不 同 的 WebService 以 及 客 户 端 调 用 代 码 , 轻 松 地 完 成 工 作 。 特 别 是 对 于 一 些 已 经 发 布 的 Web 应 用 , 可 以 通 过 直 接 修 改 页 面 的 JavaScript 代 码 及 WebService 的 方 式 对 其 进 行 改造, 达到以最小的工作量来满足用户需求的目的。
var obj = document.getElementById('Select1'); //添 加 选 项 for (var i = 0; i < rcount; i++) {
obj.add(new Option(rows.rows[i].QKDY)); //对应于 SQL 语句中的字段名称
//对 于 其 他 字 段 采 用 同 样 的 形 式 访 问 // rows.rows[i].字段名
90 2011. 03
JsonString.Append("{ "); JsonString.Append("\"count\":" + dt.Rows.Count + ",");
JsonString.Append("\"rows\":[ "); for (int i = 0; i < dt.Rows.Count; i++) {
(作者: 刘锦伟 苏丹)
如何实现数据库连接池 DDConnectionBroker 数据库连接的建立及关闭对整个计算机硬件系统与计 算机软件系统而言是耗费资源的操作, 例如建立每个与数据库 的 连 接 需 要 消 耗 CPU 处 理 时 间 与 计 算 机 内 存 等 。 在 多 层 结 构 的应用程序环境中, 这种耗费资源的动作对系统的性能影响尤 为明显。 传统的数据库连接方式中, 一个数据库连接对象均对
TROUBLESHOOTING OF PROGRAM
编程疑难问题解答
怎样在 JavaScript 中调用 WebService 获取数据
在 实 际 开 发 工 作 中 , 要 求 在 JavaScript 中 获 取 WebSer-
vice 返回的数据集, 更新页面中 HTML 控件的属性或内容。 通
//定 义 数 据 库 连 接 System.Data.OleDb.OleDbConnection con = new OleDbConnection (ConfigurationManager.ConnectionStrings[" DataCenter"].ToString()); System.Data.OleDb.OleDbDataAdapter adapter = new System.Data.OleDb.OleDbDataAdapter(cmd, con); DataSet ds = new DataSet(); try {
JsonString.Append("{ "); for (int j = 0; j < dt.Columns.Count; j++) {
if (j < dt.Columns.Count - 1) { JsonString.Append ("\"" + dt.Columns[j].ColumnName. ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\","); } else if (j == dt.Columns.Count - 1) { JsonString.Append("\"" + dt.Columns[j].ColumnName. ToString() + "\":" + "\"" + dt.Rows[i][j].ToString() + "\""); } } /*end Of String*/ if (i == dt.Rows.Count - 1) { JsonString.Append("} "); } else { JsonString.Append("}, "); } } JsonString.Append("]}"); return JsonString.ToString(); } else { return null; } }
相关文档
最新文档