• WebService连接winfrom简单实例


    C# 创建、部署和调用WebService的简单示例

    webservice 可以用于分布式应用程序之间的交互,和不同程序之间的交互。

    具体详细用法可去查询资料。下面开始创建一个简单的webservice的例子。这里我用的是Visual Studio 2013开发工具。

    首先创建一个空的Web应用程序。(只是测试demo,我把webservice和winfrom创建在一个项目下了。)创建用4.5的!

    选择Web服务,点击添加。一个简单的webservice就创建完成了,接下来编写两个简单的方法。

    然后在这里类里面加入下面的方法

    using System;

    using System.Collections.Generic;

    using System.Linq;

    using System.Web;

    using System.Web.Services;

    using System.Data.SqlClient;

    using System.Data;

     

    namespace WebServiceDemo

    {

        /// <summary>

        /// WebServiceDemo1 的摘要说明

        /// </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 WebServiceDemo1 : System.Web.Services.WebService

        {

     

            [WebMethod]

            public string HelloWorld()

            {

                return "Hello World";

            }

            //如果方法需要通过webservice的地址进行调用,那就必须在方法上面打上 [WebMethod] 的特性标签,否则是无法通过webservice访问到的。Description 是方法的描述。

            [WebMethod(Description = "求和方法")]

            public int add(string a, string b)

            {

                int sum = 0;

                sum = Convert.ToInt32(a) + Convert.ToInt32(b);

                return sum;

            }

            //定义数据库连接对象

            private SqlConnection con;

            [WebMethod]

            public DataSet GetInfo(string strSql)

            {

                string sqlConnect = "initial catalog =Northwind; server =127.0.0.1; uid = sa; pwd =sa";

                con = new SqlConnection(sqlConnect);

                con.Open();

                SqlDataAdapter da = new SqlDataAdapter(strSql, con);

                DataSet ds = new DataSet();

                da.Fill(ds);

                return ds;

            }

            [WebMethod]

            public bool testConnect()

            {

                try

                {

                    //数据库连接,定义连接对象和连接字符串并打开

                    string sqlConnect = "initial catalog =Northwind; server =127.0.0.1; uid = sa; pwd =sa";

                    con = new SqlConnection(sqlConnect);

                    con.Open();

                    return true;

                }

                catch

                {

                    return false;

                }

            }

        }

    }

    PS:如果方法需要通过webservice的地址进行调用,那就必须在方法上面打上 [WebMethod] 的特性标签,否则是无法通过webservice访问到的。Description 是方法的描述。

    然后运行一下,就可以看到上图的方法了,访问 webservice 就可以根据地址栏里的地址进行调用 webservice 的方法了。

    但是这样如何让其他应用程序通过网络进行访问呢?那就需要部署到服务器了。

    下面的演示我是部署在本机的,不过服务器部署也是一样的。网站部署需要用到 IIS,而我这里是已经开启的,如果没有开启的话,可以通过 开始菜单 > 控制面板 > 程序 > 启用或关闭 windows 功能 开启。具体的可以网上搜索一下,这里就不做过多的介绍。

    开启 IIS 之后,先把刚才的 webservice 发布之后,然后打开 IIS 管理器。

    如果出现各种报错,自行查资料!!!。

     

     

    设置不用改,继续下一步。然后点击发布。

    这样就发布完成了,现在打开 IIS 管理器,(运行输入 inetmgr  如果打不开证明ISS没有开启)然后选择网站,点击添加网站。

     

    输入网站的名称、IP地址(本机可以不输入IP地址)和端口,选择文件的路径,然后点击确定,网站就创建完成了。

    当然,并不一定就立马可以使用了,这之中会出现很多的错误,下面是我碰到的一些错误和一些解决方法。

    这个错误是因为文件的访问权限不够的问题。解决方法就是点击编辑权限。

    然后选择安全栏,点击编辑。

    然后点击添加一个用户,把权限设置为允许。或者使用下面这种方法:

    选择网站,然后选中身份验证,点击基本设置。

    选择连接为。

    然后选择特定用户,点击设置,输入本机的用户名和密码,点击确定就可以了。然后可以点击测试设置看看效果。

    这个错误的原因是在安装Framework v4.0之后,再启用IIS,导致Framework没有完全安装。

    解决方法就是:开始菜单 > 命令提示符(管理员),然后输入并执行   %windir%Microsoft.NETFrameworkv4.0.30319aspnet_regiis.exe -i   命令行。

    这个问题的是因为,应用程序池设置的原因,开始新建网站的时候没有选择应用程序池,默认为v2.0的版本,不支持 Framework 4.5。

    解决方法就是选择应用程序池,然后改为v4.0的版本,管道模式设置为集成。

    这个错误的原因是由于系统目录下的Temp目录无相应的权限所致。

    解决方法就是进入 C盘 windows 目录下的 Temp 目录,右键属性 >  安全栏 > 编辑 > IIS_IUSRS 的权限设置为完全控制。

     

    这个错误的原因是因为没有配置网站的默认文档。

    解决方法就是选中网站,点击默认文档,然后添加一个默认的页面,即应用程序的起始页面。

    然后,处理了众多问题之后,总算是部署成功了。

     

     

    在URL栏输入部署的网站地址,然后点击转到,就可以看到下面的方法内容了,然后输入web引用名称,点击添加引用。

    引用添加完成,下面就开始调用webservice。

    二创建winfrom窗口调用

    using System;

    using System.Collections.Generic;

    using System.ComponentModel;

    using System.Data;

    using System.Drawing;

    using System.Linq;

    using System.Text;

    using System.Threading.Tasks;

    using System.Windows.Forms;

     

    namespace MyWebService

    {

        public partial class Form1 : Form

        {

            public Form1()

            {

                InitializeComponent();

            }

             //初始化webservice

            WebReference.WebServiceDemo local_S = new WebReference.WebServiceDemo();

            //调用webservice连接数据库的方法

            private void button1_Click(object sender, EventArgs e)

            {

                if (local_S.testConnect())

                {

                    MessageBox.Show("连接成功");

                }

                else

                {

                    MessageBox.Show("连接失败");

                }

            }

     

            private void Form1_Load(object sender, EventArgs e)

            {

            }

            //调用webservice查询数据的方法

            private void button2_Click(object sender, EventArgs e)

            {

                string strsql = "select * from Customer";

                DataSet ds = local_S.GetInfo(strsql);

                dataGridView1.DataSource = ds.Tables[0];

            }

        }

    }

    重新发布webservice,发布之后之前添加的默认文档可能会删除。重新按照之前的步骤加入即可。然后删除之前的webservice服务应用。重新引用webservice服务。

         两个按钮事件

     

      public Form1()

            {

                InitializeComponent();

            }

             //初始化webservice

            WebReference.WebServiceDemo local_S = new WebReference.WebServiceDemo();

            //调用webservice连接数据库的方法

            private void button1_Click(object sender, EventArgs e)

            {

                if (local_S.testConnect())

                {

                    MessageBox.Show("连接成功");

                }

                else

                {

                    MessageBox.Show("连接失败");

                }

            }

            //调用webservice查询数据的方法

            private void button2_Click(object sender, EventArgs e)

            {

                string strsql = "select * from Customer";

                DataSet ds = local_S.GetInfo(strsql);

                dataGridView1.DataSource = ds.Tables[0];

            }

     

    表自己建一个

    简单的webserver在winfrom中的使用到这里就结束了。

    联系QQ同微信 78474580

  • 相关阅读:
    VS中使用svn注意事项
    后端调用WebApi
    抽象工厂模式
    观察者模式
    建造者模式
    外观模式
    模板方法
    原型模式
    工厂方法
    代理模式
  • 原文地址:https://www.cnblogs.com/debugnotes/p/10703656.html
Copyright © 2020-2023  润新知