xml web services 是 visual studio 的一个新功能,它提供在松耦合环境中使用标准协议(如 http、xml、xsd、soap 和 wsdl)交换消息的功能。可以结构化和类型化这些消息或对这些消息进行松散定义。因为 web 服务基于标准协议,所以 web 服务应用程序可以与各种不同的实现、平台和设备通讯。有关更多信息,请参阅托管代码中的 xml web services。 可以使用 web 服务增强 windows 窗体功能。连接 windows 窗体和 web 服务与调用 web 服务方法一样简单,这些方法在服务器上进行处理,然后返回方法调用的结果。 有两种类型的 web 服务方法:同步和异步。当调用同步 web 服务方法时,调用方等待 web 服务响应后再继续执行操作。当调用异步 web 服务方法时,可以在等待 web 服务响应的同时继续使用调用线程。这使得您能够在客户端应用程序中有效地使用现有的线程集合。有关使用同步和异步 web 服务方法的更多信息,请参阅使用托管代码访问 xml web services。 同步 web 服务方法 调用同步 web 服务方法包括调用该方法;等待在服务器上进行的计算并返回一个值;然后再继续执行 windows 窗体中的其他代码。 创建 xml web services
创建 web 服务应用程序。有关更多信息,请参阅创建托管代码中的 xml web services。
在解决方案资源管理器中,用右键单击 .asmx 文件并选择“查看代码”。
创建执行相加的 web 服务方法。以下 web 服务方法将两个整数相加,然后返回两者的和:
4. ' visual basic 5. <webmethod()> public function webadd(byval x as integer, byval y as integer) as integer 6. return x + y 7. end function 8. 9. // c# 10. [webmethod] 11. public int webadd(int x, int y) 12. { 13. return x + y; }
创建另一个执行相乘的 web 服务方法。以下 web 服务方法将两个整数相乘,并返回两者的积:
15. ' visual basic 16. <webmethod()> public function webmultiply(byval x as integer, byval y as integer) as integer 17. return x * y 18. end function 19. 20. // c# 21. [webmethod] 22. public int webmultiply(int x, int y) 23. { 24. return x * y; }
从“生成”菜单中,选择“生成解决方案”。也可以浏览到在此项目中创建的 .asmx 文件,以便了解 web 服务的更多信息。现在就可以从 windows 窗体调用 web 服务了。
同步调用 xml web services
创建新的 windows 应用程序。有关更多信息,请参阅创建 windows 应用程序项目。
添加对上面创建的 web 服务的引用。详细信息,请参阅添加和移除 web 引用。
从工具箱中,添加三个 textbox 控件和两个 button 控件。文本框用于数字,按钮则用于计算和调用 web 服务方法。
按以下方式设置控件的属性:
控件 属性 文本 textbox1 text 0 textbox2 text 0 textbox3 text 0 button1 text 相加 button2 text 相乘
用右键单击该窗体并选择“查看代码”。
将 web 服务的实例创建为类成员。需要知道创建上述 web 服务所在的服务器名称。
7. ' visual basic 8. ' replace localhost below with the name of the server where 9. ' you created the web service. 10. dim mathserviceclass as new localhost.service1() 11. 12. // c# localhost.service1 mathserviceclass = new localhost.service1();
14. ' visual basic 15. private sub button1_click(byval sender as system.object, byval e as system.eventargs) handles button1.click 16. ' create instances of the operands and result. 17. dim x, y, z as integer 18. ' parse the contents of the text boxes into integers. 19. x = integer.parse(textbox1.text) 20. y = integer.parse(textbox2.text) 21. ' call the webadd web service method from the instance of the web service. 22. z = mathserviceclass.webadd(x, y) 23. textbox3.text = z.tostring 24. end sub 25. 26. // c# 27. private void button1_click(object sender, system.eventargs e) 28. { 29. // create instances of the operands and result. 30. int x, y, z; 31. // parse the contents of the text boxes into integers. 32. x = int.parse(textbox1.text); 33. y = int.parse(textbox2.text); 34. // call the webadd web service method from the instance of the web service. 35. z = mathserviceclass.webadd(x, y); 36. textbox3.text = z.tostring(); }
以相同方式为 button2 的 click 事件创建事件处理程序,并添加以下代码。
38. ' visual basic 39. private sub button2_click(byval sender as system.object, byval e as system.eventargs) handles button2.click 40. ' create instances of the operands and result. 41. dim x, y, z as integer 42. ' parse the contents of the text boxes into integers. 43. x = integer.parse(textbox1.text) 44. y = integer.parse(textbox2.text) 45. ' call the webmultiply web service method from the instance of the web service. 46. z = mathserviceclass.webmultiply(x, y) 47. textbox3.text = z.tostring 48. end sub 49. 50. // c# 51. private void button2_click(object sender, system.eventargs e) 52. { 53. // create instances of the operands and result. 54. int x, y, z; 55. // parse the contents of the text boxes into integers. 56. x = int.parse(textbox1.text); 57. y = int.parse(textbox2.text); 58. // call the webadd web service method from the instance of the web service. 59. z = mathserviceclass.webmultiply(x, y); 60. textbox3.text = z.tostring(); }
注意 因为 web 服务要在服务器上实例化,所以服务器需要花费一段时间来处理第一个 web 服务调用。在应用程序中按这些按钮时,要切记这一点。下面一节处理这种时间滞后。 异步 web 服务 当调用异步 web 服务方法时,应用程序在等待 web 服务响应的同时继续运行。这使得您能够在客户端应用程序中有效地使用资源。这种在 windows 应用程序中实现 web 服务的方法非常节省资源。 详细信息,请参阅异步访问托管代码中的 xml web services。