|
問題提出:為了構(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)點是比較安全,性能較好,缺點是不便于移植,部署工作量大。
|