带有SoapHeader验证的WebServices服务创建、部署及C#中的静态调用方法
转自[Alex-D](https://blog.****.net/u012995964/article/details/54562111)
本文记录带有SoapHeader验证的WebServices服务创建、部署及C#中的静态调用方法,基于 Windows8.1
、Visual Studio 2013
、IIS8
环境实现。
WebServices服务创建
Visual Studio 2013中创建WebServices
- 创建一个空的
ASP.NET Web 应用程序
:
- 创建 WebService 服务的程序(asmx格式)文件:
首次右键“添加”时,看不到图中所示的 “Web 服务(ASMX)” ,可以点击“新建项(W)”来实现创建:
- 到此 WebService 服务创建完成,可以看到如下基础代码:
- 快捷键
F5
或ctrl + F5
运行程序如下:
此时可以点击页面的 Hello World
跳转到基于 HTTP POST
协议的调用测试页面 :
点击“调用”即可以在新的页面看到返回的结果:
添加SoapHeader验证
创建基础的WebService服务后,根据需要,有时服务会需要权限来保证安全,这里通过添加SoapHeader验证(即Soap的头信息验证)来实现。
1. 首先需要我们自己去实现一个有身份验证信息的类,这个类继承于 System.Web.Services.Protocols.SoapHeader
, 代码如下:
/// <summary>
/// 自定义MySoapHeader类
/// </summary>
public class MySoapHeader : System.Web.Services.Protocols.SoapHeader {
private string userName;
private string passWord;
public MySoapHeader() { }
public MySoapHeader(string userName, string passWord) {
this.userName = userName;
this.passWord = passWord;
}
public string UserName {
set {
userName = value;
}
get {
return userName;
}
}
public string PassWord
{
set
{
passWord = value;
}
get
{
return passWord;
}
}
}
2.修改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
{
public MySoapHeader soapHeader;
[WebMethod(Description="SoapHeader验证")]
[System.Web.Services.Protocols.SoapHeader("soapHeader")]
public string HelloWorld()
{
//简单验证用户信息
//可以通过数据库或其他方式验证
if ("admin".Equals(soapHeader.UserName) & "admin123".Equals(soapHeader.PassWord))
{
return "用户验证通过!";
}
else
{
return "对不起,您没有访问权限!";
}
}
}
至此实现了SoapHeader验证的添加,此处注意Webservice类中的方法上添加上SoapHeader特性。即上面代码中的[System.Web.Services.Protocols.SoapHeader("soapHeader")]
此处为简单实现,高级实现,可以参考MSDN提供的 教程文档
WebService服务部署
WebService服务程序的发布
编写好的web程序或者服务等,可以通过发布直接部署到服务器。这里没有远程服务器,所以使用本地的IIS服务器来运行WebService服务。发布方式如下:
后面两项配置默认即可,此时点击发布按钮,等待控制台显示如下提示,即表示发布成功:
此时可以在发布的目录中看到如下文件:
本地IIS服务部署
在本地IIS的部署可以参看前文 Windows8.1中IIS服务安装及站点配置 中站点部署的部分。
部署后浏览结果如下:
WebService的调用
创建客户端
创建控制台应用程序,用来调用测试。
添加引用
新建完项目后,需要引用WebService服务,用于调用WebService
添加完引用后,打开“Program.cs”文件的Main方法中输入以下语句:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace TestService
{
class Program
{
static void Main(string[] args)
{
//创建WebService服务实例
MyWebServices.WebService1SoapClient service = new MyWebServices.WebService1SoapClient();
//创建自定义SoapHeader对象实例
MyWebServices.MySoapHeader header = new MyWebServices.MySoapHeader();
//未设置SoapHeader的服务调用
Console.WriteLine("未设置SoapHeader的服务调用:" + service.HelloWorld(header));
Console.WriteLine();
//将用户名与密码存入SoapHeader;
header.UserName = "admin";
header.PassWord = "admin123";
////设置SoapHeader的服务调用
Console.WriteLine("未设置SoapHeader的服务调用:" + service.HelloWorld(header));
Console.Read();
}
}
}
运行后,测试结果如下: