WebSerivice例子 vs2008 客户端和服务端
建立服务端:
在VS.net2008中 新建项目->选择asp.net服务应用程序
直接按F5运行, 点HelloWorld, 点调用, 可以看到XML返回结果就说明WebService能用了.
在vs解决方案资源管理器中, 右击Service.asmx , 选择查看代码 打开Service.asmx, 在HelloWord下自己写几个测试函数:(标记了WebMethod]的可以被远程调用,
(descrition是函数说明)
public string HelloWorld() {
return "Hello World";
}
[WebMethod(Description="整数加法运算")]
public int Add(int a, int b)
{
return a + b;
}
[WebMethod(Description = "返回DataSet")]
public DataSet GetDataSet()
{
DataTable dt = new DataTable();
dt.Columns.Add("name");
dt.Columns.Add("age");
dt.Columns.Add("sex");
DataRow dr = dt.NewRow();
dr["name"] = "jack";
dr["age"] = "25";
dr["sex"] = "男";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["name"] = "cherry";
dr["age"] = "26";
dr["sex"] = "女";
dt.Rows.Add(dr);
DataSet ds = new DataSet();
ds.Tables.Add(dt);
return ds;
}
按F5运行, 网页地址假设为http://localhost:2582/WebSite1/Service.asmx (下面客户端要调用). 可以看到三个函数, 服务端完成了.return "Hello World";
}
[WebMethod(Description="整数加法运算")]
public int Add(int a, int b)
{
return a + b;
}
[WebMethod(Description = "返回DataSet")]
public DataSet GetDataSet()
{
DataTable dt = new DataTable();
dt.Columns.Add("name");
dt.Columns.Add("age");
dt.Columns.Add("sex");
DataRow dr = dt.NewRow();
dr["name"] = "jack";
dr["age"] = "25";
dr["sex"] = "男";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["name"] = "cherry";
dr["age"] = "26";
dr["sex"] = "女";
dt.Rows.Add(dr);
DataSet ds = new DataSet();
ds.Tables.Add(dt);
return ds;
}
客户端:
可以是Console, Web, Winform.这儿以Console平台为例:
新建一个Console项目.
在解决方案引上右击选择"添加服务引用..."
然后把上面的webService服务地址复制过来, 点下前往就能看到函数了.
修改下命名空间, 每个WebService要个独立的命名空间, 以防止与当前项目类名相同.
修改main函数:
static void Main(string[] args)
{
MyService.ServiceSoapClient client = new MyService.ServiceSoapClient();
int result = client.Add(1, 2);
MyService.ServiceSoapClient client1 = new MyService.ServiceSoapClient();
int result1 = client.Add(1, 2);
MyService.ServiceSoapClient client2 = new MyService.ServiceSoapClient();
int result2 = client2.Add(2, 2);
Console.WriteLine(result + "\n" + result1 + "\n" + result2);
//DataTable DataRow DataView DataColumn都不能在webservices中传过来 只能用dataset了
DataTable dt = client.GetDataSet().Tables[0];
foreach (DataRow dr in dt.Rows)
{
string str = "";
foreach (DataColumn dc in dt.Columns)
{
str += dr[dc].ToString() + "\t";
}
Console.WriteLine(str);
}
Console.ReadKey();
}
运行可以看到调用了. 客户端要新建项目, 服务端那个项目运行不要关闭. MyService.ServiceSoapClient client = new MyService.ServiceSoapClient();
int result = client.Add(1, 2);
MyService.ServiceSoapClient client1 = new MyService.ServiceSoapClient();
int result1 = client.Add(1, 2);
MyService.ServiceSoapClient client2 = new MyService.ServiceSoapClient();
int result2 = client2.Add(2, 2);
Console.WriteLine(result + "\n" + result1 + "\n" + result2);
//DataTable DataRow DataView DataColumn都不能在webservices中传过来 只能用dataset了
DataTable dt = client.GetDataSet().Tables[0];
foreach (DataRow dr in dt.Rows)
{
string str = "";
foreach (DataColumn dc in dt.Columns)
{
str += dr[dc].ToString() + "\t";
}
Console.WriteLine(str);
}
Console.ReadKey();
}
如果WebService想发布, 选择发布网站, 把生成的dll, 拷贝到IIS运行程序目录中. 客户端修改app.config文件, 改成实际地址.
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2010-11-18 t-sql中with用法
2010-11-18 sql排名次 rank()用法