zoukankan      html  css  js  c++  java
  • 带SoapHeader验证的WebServices

    一般在项目中,制作的都是基于SOAP协议的webservices,其描述语言是WSDL。但是有时候在项目中,需要保证webservices的安全,需要对其进行进行验证,那么我们就要实现SoapHeader,具体的实现方式如下:

    首先就是自定义一个类,继承自System.Web.Services.Protocols.SoapHeader ,然后在这个类中,通过暴露的公共属性和方法来进行校验。

    其次就是在webservices主体方法中,添加对SoapHeader的验证的支持

    最后直接在用户页面进行验证,调用方法即可。

    首先,定义一个sSoapHeader类,暴露出其提供的公共验证字段,并提供验证方法:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;

    namespace webServiceDemo
    {
        
    public class sSoapHeader:System.Web.Services.Protocols.SoapHeader
        {
            
    private string _UserId = string.Empty;
            
    private string _UserPwd = string.Empty;

            
    public sSoapHeader() { }

            
    public string UserId
            {
                
    get
                {
                    
    return _UserId;
                }
                
    set
                {
                    _UserId 
    = value;
                }
            }

            
    public string UserPwd
            {
                
    get
                {
                    
    return _UserPwd;
                }
                
    set
                {
                    _UserPwd 
    = value;
                }
            }

            
    public void Initial(string username, string password)
            {
                UserId 
    = username;
                UserPwd 
    = password;
            }

            
    public bool IsValid(string uid, string pwd, out string msg)
            {
                msg 
    = "";
                
    if (uid == "admin" && pwd == "admin888")
                {
                    
    return true;
                }
                
    else
                {
                    msg 
    = "对不起,你无法调用";
                    
    return false;
                }
            }
            
    public bool IsValid(out string msg)
            {
                
    return IsValid(_UserId, _UserPwd, out msg);
            }

        }
    }

    其次就是在webservice主体中,添加对此验证方法的支持

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Services;
    using System.Web.Services.Protocols;

    namespace webServiceDemo
    {
        
    /// <summary>
        
    /// Service1 的摘要说明
        
    /// </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 Service1 : System.Web.Services.WebService
        {
            
    public sSoapHeader s = new sSoapHeader();
            [SoapHeader(
    "s")]   //这里就是添加验证方法的标志
            [WebMethod]
            
    public string HelloWorld(int a,int b)
            {
                
    string msg = "";
                
    if (!s.IsValid(out msg))
                {
                    
    return msg;
                }
                
    return (a + b).ToString();
            }

           
        }
    }

    在上图中,我已经标志的很清楚了[SoapHeader("s")] 就是添加验证方法的标志。

    最后就是在用户页面中进行调用,引用完毕后,需要对soapheader暴露的公共属性方法进行赋值判断,最后调用即可。只要验证正确,便可以正常调用,否则则提示没有权限:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.UI;
    using System.Web.UI.WebControls;

    namespace WEB
    {
        
    public partial class _Default : System.Web.UI.Page
        {
            
    protected void Page_Load(object sender, EventArgs e)
            {
                localhost.Service1 s 
    = new WEB.localhost.Service1();
                localhost.sSoapHeader header 
    = new WEB.localhost.sSoapHeader();
                header.UserId 
    = "admin";
                header.UserPwd 
    = "admin888";
                s.sSoapHeaderValue 
    = header;
                Response.Write(s.HelloWorld(
    2,1));
            }
        }
    }
  • 相关阅读:
    codeforces #330 div2
    codeforces #332 div2
    Codeforces Round #331 (Div. 2)C. Wilbur and Points
    poj 01背包
    zoj 1200 Mining
    nginx反向代理与负载均衡
    springcloud----config分布式配置中心
    springcloud--zuul 网关
    springcloud ----Hystrix熔断器
    docker私有镜像仓库harbor搭建和配置
  • 原文地址:https://www.cnblogs.com/scy251147/p/2013069.html
Copyright © 2011-2022 走看看