小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

簡單Web service 身份驗證解決方案

 Joshua 2006-02-20

問題提出:為了構(gòu)建一個安全的web服務(wù),需要對調(diào)用方進(jìn)行身份驗證,只讓通過審核的用戶調(diào)用web服務(wù)。

軟件件環(huán)境:Web服務(wù)程序部署在分布于各地的工廠服務(wù)器,這些服務(wù)器位于內(nèi)網(wǎng)之中,沒有固定外網(wǎng)IP,且不能通過外網(wǎng)進(jìn)行訪問。調(diào)用這些Web服務(wù)的是一臺連接至internet的WEB服務(wù)器,該WEB服務(wù)器通過VPN與各個工廠的服務(wù)器相連。

解決方案一:通過SOAP Header傳遞用戶名和密碼。

1. 首先需要在服務(wù)中定義一個從 SOAPHeader 派生的類,表示傳入 SOAP 標(biāo)頭的數(shù)據(jù)。

public class CredentialSoapHeader : System.Web.Services.Protocols.SoapHeader
 {
  private string _UserID=string.Empty;
  private string _PassWord=string.Empty;

  public string UserID
  {
   get{return _UserID;}
   set{_UserID=value;}
  }
  public string PassWord
  {
   get{return _PassWord;}
   set{_PassWord=value;}
  }
 
  public void Initial(string nUserID,string nPassWord)
  {
   UserID=nUserID;
   PassWord=nPassWord;
  }

  public bool IsValid(string nUserID,string nPassWord,out string nMsg)
  {
   nMsg="";
   try
   {
    //判斷用戶名密碼是否正確
    if(nUserID == "admin" && nPassWord == "admin")
    {
     return true;
    }
    else
    {
     nMsg="對不起,你無權(quán)調(diào)用此Web服務(wù),可能有如下原因:\n 1.您的賬號被管理員禁用。\n 2.您的賬號密碼不正確";
     return false;
    }
   }
   catch
   {
    nMsg="對不起,你無權(quán)調(diào)用此Web服務(wù),可能有如下原因:\n 1.您的賬號被管理員禁用。\n 2.您的賬號密碼不正確";
    return false;
   }
  }

  /// <summary>
  /// 用戶名密碼是否正確
  /// </summary>
  /// <returns>用戶名密碼是否正確</returns>

  public bool IsValid(out string nMsg)
  {
   return IsValid(_UserID,_PassWord,out nMsg);
  }
 }

2. 在Web Services使用 SoapHeader 自定義屬性定義一組關(guān)聯(lián)的標(biāo)頭,服務(wù)中的每個 WebMethod 都可以使用.(默認(rèn)情況下,標(biāo)頭是必需的,但也可以定義可選標(biāo)頭)

Test.asmx代碼片段:

 public CredentialSoapHeader myHeader=new CredentialSoapHeader();

 // WEB 服務(wù)示例
 [SoapHeader("myHeader")]
 [WebMethod(Description="加入了身份驗證的web服務(wù)",EnableSession=true)]
 public string HelloWorld (string contents)
 {
  string msg = "";
  //驗證是否有權(quán)訪問
  if(!myHeader.IsValid(out msg))
   return msg;
  return "Hello World:"+contents;
 }

3. 最后客戶端在調(diào)用要求標(biāo)頭的方法之前,需直接在代理類上設(shè)置標(biāo)頭。
以下是winform客戶段代碼片段:
SoapTest.Test test1 = new SoapHeader.SoapTest.Test();
//創(chuàng)建soap頭對象
SoapTest.CredentialSoapHeader header = new SoapHeader.SoapTest.CredentialSoapHeader();
/設(shè)置soap頭變量
header.PassWord = "admin";
header.UserID = "admin1";
test1.CredentialSoapHeaderValue = header;
//調(diào)用web 方法
this.label1.Text = test1.HelloWorld ("wang");

通過以上步驟就可以完成Web Services自定義身份驗證了.

該方案的優(yōu)點是代碼靈活,便于移植,缺點是傳遞的信息沒有加密,可配合SSL進(jìn)行使用。

解決方案二:通過集成windows身份驗證。
1. 將web服務(wù)程序設(shè)為集成windows身份驗證 
 

2.客戶端web引用代碼
Test.WebReference.Service1 wr = new Test.WebReference.Service1(); //生成web service實例
wr.Credentials = new NetworkCredential("guest","123"); //guest是用戶名,該用戶需要有一定的權(quán)限
lblTest.Text = wr.Add(2,2).ToString(); //調(diào)用web service方法
該方案的優(yōu)點是比較安全,性能較好,缺點是不便于移植,部署工作量大。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多