WebService连接winfrom简单实例
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.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