WebService链接winfrom简单实例

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

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

webservice 能够用于分布式应用程序之间的交互,和不一样程序之间的交互。web

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

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

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

而后在这里类里面加入下面的方法安全

 

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.NET\Framework\v4.0.30319\aspnet_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

相关文章
相关标签/搜索