首页>
知识库>
详情

WinCE数据通讯之WebService篇

2020-07-23 来源:CloudBest 阅读量: 0
关键词:

    准备写个WinCE平台与数据库服务器数据通讯交互方面的专题文章,今天先整理个Web Service通讯方式。
    公司目前的硬件产品平台是WinCE5.0,数据通讯是连接服务器与终端的桥梁,关系着终端的数据能否准确及时高效抵达服务器,是整个项目成败的关键。原先公司有同事用VC写过一个程序用Socket进行数据通讯,但一直问题不断。年前我开始探索用SqlCE与SqlServer数据同步方式进行数据上传与下载,通讯已经正常稳定。这方面的文章后续再整理。
    Web Service用于PC间通讯的文章网上有很多,但用于WinCE平台调用的经验总结并不多见。Web Service的程序编写与配置调用相对来讲比较简单,Visual Studio里直接新建一个“Asp.net web 服务应用程序”就可以创建一个web Service项目了。其中的代码根据实际需求编写就行,这方面就不详述了。
    终端设备是通过GPRS来进行数据传输的,因此,数据流量是非常重要的问题,应当尽可能少的减少数据传输,流量可是Money,压缩技术是关键。Google大法,找到了一款物美价廉的东东-Ihttp://www.icsharpcode.net/OpenSource/SharpZipLib/Default.aspx 所谓物美是这款代码支持Dot net CF平台,所谓价廉是这款代码完全开源免费。
    操刀开工……先建一个直接返回DataSet集的Web Service服务
    Code
    private SqlConnection Conn;
    private string ConnString = "Data Source=(local);Initial Catalog=Northwind;uid=sa;pwd=sa;";
    dataConnection#region dataConnection
    private DataSet GetNorthwindDataSet()
    {
    return ExecuteSql("select * from Employees");
    }
    private DataSet ExecuteSql(string mysql)
    {
    DataSet dataSet = new DataSet();
    SqlDataAdapter adapter = new SqlDataAdapter(mysql, this.Conn);
    try
    {
    if (this.Conn.State == ConnectionState.Closed)
    {
    this.Conn.Open();
    }
    adapter.Fill(dataSet, "table");
    }
    catch (Exception exception)
    {
    HttpContext.Current.Response.Write(exception.Message);
    HttpContext.Current.Response.End();
    }
    finally
    {
    if ((this.Conn != null) && (this.Conn.State == ConnectionState.Open))
    {
    this.Conn.Close();
    }
    adapter.Dispose();
    }
    return dataSet;
    }
    #endregion
    //方法一:直接返回 DataSet 对象
    [WebMethod(Description = "直接返回 DataSet 对象。")]
    public DataSet GetDataSet()
    {
    DataSet dataSet = GetNorthwindDataSet();
    return dataSet;
    }
    建立一个智能设备应用程序,添加Web引用,我这里用的是静态引用,没有用动态引用的原因是,试过网上的动态生成WebService引用的代码,效率远比静态引用要低很多,考虑终端设备资源的有限性,还是用的静态引用。建立好项目后在界面上添加一个button和datagrid控件,添加代码:
    Code
    private webSer.Service1 ws;
    private void FrmMain_Load(object sender, EventArgs e)
    {
    ws = new DeviceApplication1.webSer.Service1();
    }
    //webmethod直接返回dataset
    private void btnDataSet_Click(object sender, EventArgs e)
    {
    try
    {
    this.dtGrid.DataSource = null;
    DateTime dtBegin = DateTime.Now;
    DataSet ds = ws.GetDataSet();
    DateTime dtDown = DateTime.Now;
    this.dtGrid.DataSource = ds.Tables[0];
    MessageBox.Show(string.Format("下载耗时:{0},绑定数据耗时:{1},数据量:{2}",
    dtDown - dtBegin, DateTime.Now - dtDown, ds.GetXml()。Length));
    }
    catch (Exception ex)
    {
    MessageBox.Show(ex.ToString());
    }
    }
    连接好终端设备,测试点击按钮,几秒后DataGrid表格正确显示数据,OK,说明WinCE已经能够正确调用Web Service了。如果不能正确调用,检察WebService发布与Web引用是否正确,数据库配置是否正确。