在WebService加入安全验证

WebService的优点就不多说了,使用XML作为数据格式,可以跨平台、跨语言与多种应用程序交互。

今天,我们来实现在WebService中加入安全验证机制。

我们先,建立一个ASP.NET项目,在其中添加一个DemoService的WebService。

/// <summary>
/// DemoService 的摘要说明
/// </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 DemoService : System.Web.Services.WebService
{
 
    [WebMethod]
    public string HelloWorld()
    {
        return "Hello World";
    }
}

一切都是默认的,之后,我们再加入一个Windows控制台项目,添加Web引用,将刚刚建好的WebService加入到项目中,并调用该WebService。

显示结果:

接下来,我们使用令牌的方式为WebService添加安全验证。

1.New一个安全令牌类,这个类要继承SoapHeader,我们是利用SoapHeader实现安全验证的。

/// <summary>
/// 安全验证令牌
/// </summary>
public class SecurityToken : SoapHeader
{
    //安全密钥
    public string Key { get; set; }
}

2.修改WebService的的类,支持安全验证

/// <summary>
/// DemoService 的摘要说明
/// </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 DemoService : System.Web.Services.WebService
{
    //公有令牌变量
    public SecurityToken Token;
 
    [WebMethod]
    [SoapHeader("Token")]   //声明需要调用安全令牌
    public string HelloWorld()
    {
        if (!this.IsValiToken())
            return string.Empty;
        return "Hello World";
    }
 
    /// <summary>
    /// 验证是安全令牌是否正确
    /// </summary>
    /// <returns></returns>
    private bool IsValiToken()
    {
        bool flag = false;
        if (this.Token != null && this.Token.Key == "dotnetdev.cn")
            flag = true;
        return flag;
    }
}

3.修改调用端。更新WebService引用,修改代码。

//实例化WebService
ServiceReference.DemoServiceSoapClient client = new ServiceReference.DemoServiceSoapClient();
//实例化令牌
ServiceReference.SecurityToken token = new ServiceReference.SecurityToken();
//设置令牌的密钥
token.Key = "dotnetdev.cn";
//调用WebService
Console.WriteLine(client.HelloWorld(token));
Console.ReadKey();

注:这里使用的是添加服务引用的方式,如果添加Web引用的方式可能稍显不同。不过原理是一样的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值