接着上一章的内容,在上一章中我们知道了如何.net平台下去建立一个WebService,以及同步调用、异步调用、开线程异步调用三种客户端从服务端获取数据的方式,在本章了所要讲的,是如何将客户端的数据,传递给服务端,进行客户端和服务端的双相交互

服务端

建立UserManager.cs类,添加using System.Web.Services.Protocols;命名空间,并使它继承自SoapHeader
输入以下代码

  1.  
    public class UserManager:SoapHeader
  2.  
    {
  3.  
    public string Name { get; set; }
  4.  
    public string Pwd { get; set; }
  5.  
     
  6.  
     
  7.  
    private bool CheckUser(string n,string p)
  8.  
    {
  9.  
    if(Name == "aaa" && Pwd == "bbb")
  10.  
    {
  11.  
    return true;
  12.  
    }
  13.  
    else
  14.  
    {
  15.  
    return false;
  16.  
    }
  17.  
    }
  18.  
     
  19.  
     
  20.  
    public bool CheckUser()
  21.  
    {
  22.  
    return CheckUser(Name, Pwd);
  23.  
    }
  24.  
    }

在服务端的WSDemo.asmx文件中输入以下代码

  1.  
    public class WSDemo : System.Web.Services.WebService
  2.  
    {
  3.  
     
  4.  
     
  5.  
    [WebMethod]
  6.  
    public string HelloWorld()
  7.  
    {
  8.  
    return "Hello World";
  9.  
    }
  10.  
     
  11.  
     
  12.  
    //标准一下CheckUser()方法使用哪个SoapHeader进行校验,客户端网站调用该方法时需要指定自己定义的SoapHeader内容
  13.  
    //这样,虽然CheckUser()并没有参数,但在在使用时,要先定义UserManager的SoapHeader的头,放在CheckUser中
  14.  
    public UserManager um;
  15.  
    [SoapHeader("um")]
  16.  
    [WebMethod(Description = "用户验证")]
  17.  
    public bool CheckUser()
  18.  
    {
  19.  
    if (um.CheckUser())
  20.  
    {
  21.  
    return true;
  22.  
    }
  23.  
    else
  24.  
    {
  25.  
    return false;
  26.  
    }
  27.  
    }
  28.  
    }

至此,服务端操作完毕

客户端---同步方式

操作完服务端后,要在ServiceReference1上右击“更新服务引用”

图10
在Index.aspx.cs中输入以下代码:

  1.  
    public partial class Index : System.Web.UI.Page
  2.  
    {
  3.  
    protected string stator = string.Empty;
  4.  
    protected void Page_Load(object sender, EventArgs e)
  5.  
    {
  6.  
    using (ServiceReference1.WSDemoSoapClient wsc = new WSDemoSoapClient())
  7.  
    {
  8.  
    //UserManager服务端中的类名
  9.  
    ServiceReference1.UserManager um = new UserManager();
  10.  
    um.Name = "aaa";
  11.  
    um.Pwd = "bbb";
  12.  
    stator = wsc.CheckUser(um)?"登录成功":"用户名或密码错误";//三目运算符,更据服务端返回值确定向浏览器输出内容
  13.  
    }
  14.  
    Response.Write(stator);
  15.  
    }
  16.  
    }

至此,客户端操作完毕,此时可发现在用户名和密码不对的情况下,浏览器所输入的值

客户端---异步方式

将Index.aspx.cs中的代码修改为以下方式

  1.  
    public partial class Index : System.Web.UI.Page
  2.  
    {
  3.  
    protected string stator = string.Empty;
  4.  
    protected void Page_Load(object sender, EventArgs e)
  5.  
    {
  6.  
    using (ServiceReference1.WSDemoSoapClient client = new WSDemoSoapClient())
  7.  
    {
  8.  
    //要执行的方法
  9.  
    client.CheckUserCompleted += new EventHandler<CheckUserCompletedEventArgs>(client_CheckUserCompleted);
  10.  
    //为传参做准备,因为添加了“服务引用”所以在客户端也能点出服务端中公布的的方法来
  11.  
    ServiceReference1.UserManager um = new UserManager();
  12.  
    um.Name = "aaa";
  13.  
    um.Pwd = "bbb";
  14.  
    //开始执行
  15.  
    client.CheckUserAsync(um);
  16.  
    }
  17.  
    }
  18.  
    //要执行的方法
  19.  
    void client_CheckUserCompleted(object sender, CheckUserCompletedEventArgs e)
  20.  
    {
  21.  
    stator = e.Result ? "登录成功" : "登录失败";
  22.  
    Response.Write(stator);
  23.  
    }
  24.  
    }

客户端---开线程的异步方式

将Index.aspx.cs中代码更改为以下形式

  1.  
    public partial class Index : System.Web.UI.Page
  2.  
    {
  3.  
    protected string stator = string.Empty;
  4.  
    protected void Page_Load(object sender, EventArgs e)
  5.  
    {
  6.  
    BackgroundWorker bw = new BackgroundWorker();
  7.  
    bw.DoWork += new DoWorkEventHandler(bw_DoWork);//指明线程要执行方法
  8.  
    bw.RunWorkerCompleted += new RunWorkerCompletedEventHandler(bw_RunWorkerCompleted);//获取从服务端中的返回值
  9.  
    bw.RunWorkerAsync();//开始执行
  10.  
    }
  11.  
    //获取从服务端中的返回值
  12.  
    void bw_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
  13.  
    {
  14.  
    stator = (bool)e.Result ? "登录成功" : "登录失败";
  15.  
    Response.Write(stator);
  16.  
    }
  17.  
    //指明线程要执行方法
  18.  
    void bw_DoWork(object sender, DoWorkEventArgs e)
  19.  
    {
  20.  
    //建立客户端和服务端的链接
  21.  
    using (ServiceReference1.WSDemoSoapClient client = new WSDemoSoapClient())
  22.  
    {
  23.  
    //对服务端公布方法UserManager进行实例化并赋值
  24.  
    UserManager um = new UserManager();
  25.  
    um.Name = "aaa";
  26.  
    um.Pwd = "bbb";
  27.  
    //调用服务端方法,并传入参数
  28.  
    e.Result = client.CheckUser(um);//注意e.Result = ...
  29.  
    }
  30.  
    }
  31.  
    }

至此,开线程异步客户端传参与服务器数据交互操作完毕

出处:https://blog.csdn.net/zhangquanok/article/details/15338697

WebService的web客户端同步、异步、多线程向服务端传入参数的数据交互方式的更多相关文章

  1. 在Android中调用KSOAP2库访问webservice服务出现的服务端传入参数为null的问题解决

    ksoap2-android-3.0.0-jar 第三方库来调用.net 写的Web Service 如果没有参数,那么调用一切顺利,但是如果服务是带参数的,那么服务端接收的参数都是nul.      ...

  2. c++ 网络编程(九)LINUX/windows-IOCP模型 多线程超详细教程及多线程实现服务端

    原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9661012.html 先讲Linux下(windows下在后面可以直接跳到后面看): 一.线程 ...

  3. (转)客户端触发Asp.net中服务端控件事件

    第一章. Asp.net中服务端控件事件是如何触发的 Asp.net 中在客户端触发服务端事件分为两种情况: 一. WebControls中的Button 和HtmlControls中的Type为su ...

  4. python并发编程-多线程实现服务端并发-GIL全局解释器锁-验证python多线程是否有用-死锁-递归锁-信号量-Event事件-线程结合队列-03

    目录 结合多线程实现服务端并发(不用socketserver模块) 服务端代码 客户端代码 CIL全局解释器锁****** 可能被问到的两个判断 与普通互斥锁的区别 验证python的多线程是否有用需 ...

  5. WebSocket安卓客户端实现详解(三)–服务端主动通知

    WebSocket安卓客户端实现详解(三)–服务端主动通知 本篇依旧是接着上一篇继续扩展,还没看过之前博客的小伙伴,这里附上前几篇地址 WebSocket安卓客户端实现详解(一)–连接建立与重连 We ...

  6. Android-低功耗蓝牙(BLE)-客户端(主机/中心设备)和服务端(从机/外围设备)

    一.Android 低功耗蓝牙(BLE)的API简介 从Android 4.3(API 18)才支持低功耗蓝牙(Bluetooth Low Energy, BLE)的核心功能, BLE蓝牙协议是GAT ...

  7. (8)Linux(客户端)和Windows(服务端)下socket通信实例

    Linux(客户端)和Windows(服务端)下socket通信实例: (1)首先是Windows做客户端,Linux做服务端的程序 Windows   Client端 #include <st ...

  8. 编写Java程序,使用 Socket类模拟用户加入 QQ 群时,QQ 小冰发送欢迎消息的场景(用户充当客户端,QQ 小冰充当服务端)

    查看本章节 查看作业目录 需求说明: 小冰是微软公司研发的人工智能机器人,被腾讯公司加入 QQ 群后,立即受到千万网友的喜爱.现在使用 Socket类模拟用户加入 QQ 群时,QQ 小冰发送欢迎消息的 ...

  9. webservice 服务端例子+客户端例子+CXF整合spring服务端测试+生成wsdl文件 +cxf客户端代码自动生成

    首先到CXF官网及spring官网下载相关jar架包,这个不多说.webservice是干嘛用的也不多说. 入门例子 模拟新增一个用户,并返回新增结果,成功还是失败. 大概的目录如上,很简单. Res ...

随机推荐

  1. LTE时代的定位技术:OTDOA,LPP,SUPL2.0

    LTE时代的定位技术:OTDOA,LPP,SUPL2.0 移动定位技术的发展历程 如今智能手机已经在整个社会普及,数量众多的手机应用成为了人们生活当中不可或缺的一部分.越来越多的手机应用都用到了手机定 ...

  2. Linux 强制安装rpm 包

    Linux 强制安装rpm 包 2014年12月12日 10:21 [root@ilearndb1 Server]# rpm -ivh  unixODBC-devel-2.*  --nodeps -- ...

  3. SMTP 发邮件

    public class EmailOrderProcessor :IOrderProcessor { private EmailSettings es; public EmailOrderProce ...

  4. Nginx 关于 location 的匹配规则详解

    有些童鞋的误区 1. location 的匹配顺序是“先匹配正则,再匹配普通”. 矫正: location 的匹配顺序其实是“先匹配普通,再匹配正则”.我这么说,大家一定会反驳我,因为按“先匹配普通, ...

  5. MyBatis:2

    转载:http://www.cnblogs.com/xrq730/p/5256221.html 前言 前一篇文章,讲了MyBatis入门,讲到了MyBatis有两个基本的配置文件,一个用来配置环境信息 ...

  6. CachedThreadPool里的线程是如何被回收的?

    线程池创建线程的逻辑图: 我们分析CachedThreadPool线程池里的线程是如何被回收的. //Executors public static ExecutorService newCached ...

  7. anaconda环境变量+修改jupyter默认路径

    手贱在安装的时候没有点添加环境变量 安装好后,用anaconda prompt运行一些程序命令之类都是可以的,但是直接打开cmd就不行了,为了省事,所以决定手动添加环境变量, %\ProgramDat ...

  8. POJ 3352 Road Construction 双联通分量 难度:1

    http://poj.org/problem?id=3352 有重边的话重边就不被包含在双连通里了 割点不一定连着割边,因为这个图不一定是点连通,所以可能出现反而多增加了双连通分量数的可能 必须要用割 ...

  9. 51nod1269Devu and Flowers

    题解: 如果没有限制每一种花有多少,那么就是简单的排列组合问题. 那么我们强制让一些花一定都要选. 暴力搜索,然后组合数(逆元) 采用容斥原理来计算最后的答案 代码: #include<bits ...

  10. Java——IO类,转换流简化写法

    body, table{font-family: 微软雅黑} table{border-collapse: collapse; border: solid gray; border-width: 2p ...