zoukankan      html  css  js  c++  java
  • C# webservice 编写、发布、调用

    采用的工具VS2010生成工程

    1. 生成webservice工程:建 ASP.NET 空WEB 应用程序。

    2. 在建好的ASP.NET 空WEB应用程序中新建项“web 服务”。

    完成上述内容工程结构如下图

    下面主要的操作就是在webservice1.asmx.cs文件中进行,里面写了几个服务,两个简单服务两个查询数据库服务;

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Services;
    using System.Data.SqlClient;
    using System.Data;
    using MySql.Data;
    using MySql;
    using MySql.Data.MySqlClient;
     
    namespace webservice
    {
        /// <summary>
        /// WebService1 的摘要说明
        /// </summary>
        [WebService(Namespace = "http://tempuri.org/")]
        [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
        [System.ComponentModel.ToolboxItem(false)]
        // 若要允许使用 ASP.NET AJAX 从脚本中调用此 Web 服务,请取消对下行的注释。
        // [System.Web.Script.Services.ScriptService]
        public  class WebService1 : System.Web.Services.WebService
        {
     
            [WebMethod]
            public string HelloWorld()
            {
                return "Hello World";
            }
     
            [WebMethod]
            public int GetSum(int a, int b)
            {
                return a + b;
            }
     
            [WebMethod]
            public DataSet query()
            {
                DataSet ds = new DataSet();
                string connstring = "Database=test;Data Source=localhost;User Id=root;Password=root";
                MySqlConnection mycn = new MySqlConnection(connstring);
                mycn.Open();
                MySqlDataAdapter mda = new MySqlDataAdapter("select * from stock_data", mycn);
                mda.Fill(ds,"stock_data");           
                return ds;
            }
     
            [WebMethod]
            public DataSet goldprice()
            {
                DataSet ds = new DataSet();
                string connstring = "Database=test;Data Source=localhost;User Id=root;Password=root";
                MySqlConnection mycn = new MySqlConnection(connstring);
                mycn.Open();
                MySqlDataAdapter mda = new MySqlDataAdapter("select * from goldprice", mycn);
                mda.Fill(ds, "stock_data");
                return ds;
            }
     
             
        }
    }

     到目前为至C# 的webservice的服务算是写好了。下面我们需要启动些服务F5

    运行成功的界面如下图

    二:发布此webservice

    1. 与发布asp.net是一样的,首先在IIS的网站节点下添加网站;如下图

    2. webservice发布到IIS的虚拟目录;选择webservice工程右击点发布进行发布如下图

    3. 修改此网站的高级设置: 把应用程序池修改为ASP.NET v4.0即可。

    4. 浏览此网站http://192.168.56.1/WebService1.asmx若运行的效果与在VS2010运行的效果一样则部署成功了。

    三:webservice服务调用

    1. 新建一个测试工程,在工程的引用节点中右击“添加服务引用”把浏览器中的URL填写到地址框中点前往,并修改命名空间;如下图

    2. 然后再重新生成一下测试项目,最后在测试项目中定义一个测试方法并调用webservice中的方法。代码如下

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    private void button1_Click(object sender, RoutedEventArgs e)
            {
                YDTF.WebService1SoapClient aa = new YDTF.WebService1SoapClient();
                button1.Content = aa.HelloWorld();
                Menus m = new Menus();
                m.Name = "Name";
                m.NameSpace = "NameSpace";
                DataSet ds = aa.query();
                int i = ds.Tables[0].Rows.Count;
            }

    3. 单步调试一下若运行结果和预料一样则成功了。

  • 相关阅读:
    用户模式同步之互斥体小解
    用户模式同步之信号量小解
    用户模式同步之事件小解
    中断和异常
    断点之软件断点的一些基本知识(INT3)
    部署Django项目Nginx + uwsgi
    CentOS切换root用户一直提示Incorrect password
    一张图看懂Mysql的join连接
    Nginx部署入门
    Django使用多个数据库
  • 原文地址:https://www.cnblogs.com/wanzhongjun/p/6841844.html
Copyright © 2011-2022 走看看