欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

簡(jiǎn)單Web service 身份驗(yàn)證解決方案

 更新時(shí)間:2009年05月06日 03:03:11   作者:  
問題提出:為了構(gòu)建一個(gè)安全的web服務(wù),需要對(duì)調(diào)用方進(jìn)行身份驗(yà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ù)的是一臺(tái)連接至internet的WEB服務(wù)器,該WEB服務(wù)器通過VPN與各個(gè)工廠的服務(wù)器相連。

解決方案一:通過SOAP Header傳遞用戶名和密碼。
1. 首先需要在服務(wù)中定義一個(gè)從 SOAPHeader 派生的類,表示傳入 SOAP 標(biāo)頭的數(shù)據(jù)。

復(fù)制代碼 代碼如下:

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="對(duì)不起,你無權(quán)調(diào)用此Web服務(wù),可能有如下原因:\n 1.您的帳號(hào)被管理員禁用。\n 2.您的帳號(hào)密碼不正確";
return false;
}
}
catch
{
nMsg="對(duì)不起,你無權(quán)調(diào)用此Web服務(wù),可能有如下原因:\n 1.您的帳號(hào)被管理員禁用。\n 2.您的帳號(hào)密碼不正確";
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ù)中的每個(gè) WebMethod 都可以使用.(默認(rèn)情況下,標(biāo)頭是必需的,但也可以定義可選標(biāo)頭)
Test.asmx代碼片段:
復(fù)制代碼 代碼如下:

public CredentialSoapHeader myHeader=new CredentialSoapHeader();

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

3. 最后客戶端在調(diào)用要求標(biāo)頭的方法之前,需直接在代理類上設(shè)置標(biāo)頭。
以下是winform客戶端代碼片段:
復(fù)制代碼 代碼如下:

SoapTest.Test test1 = new SoapHeader.SoapTest.Test();
//創(chuàng)建soap頭對(duì)象
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àn)證了. 該方案的優(yōu)點(diǎn)是代碼靈活,便于移植,缺點(diǎn)是傳遞的信息沒有加密,可配合SSL進(jìn)行使用。
解決方案二:通過集成windows身份驗(yàn)證。
1. 將web服務(wù)程序設(shè)為集成windows身份驗(yàn)證。

2.客戶端web引用代碼
復(fù)制代碼 代碼如下:

Test.WebReference.Service1 wr = new Test.WebReference.Service1(); //生成web service實(shí)例
wr.Credentials = new NetworkCredential("guest","123"); //guest是用戶名,該用戶需要有一定的權(quán)限
lblTest.Text = wr.Add(2,2).ToString(); //調(diào)用web service方法

該方案的優(yōu)點(diǎn)是比較安全,性能較好,缺點(diǎn)是不便于移植,部署工作量大。

相關(guān)文章

  • ASP.NET MVC結(jié)合JavaScript登錄、校驗(yàn)和加密

    ASP.NET MVC結(jié)合JavaScript登錄、校驗(yàn)和加密

    這篇文章主要為大家詳細(xì)介紹了ASP.NET MVC結(jié)合JavaScript登錄、校驗(yàn)和加密的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • 獲取根目錄的URL例如http://localhost:51898

    獲取根目錄的URL例如http://localhost:51898

    這篇文章主要介紹了獲取根目錄的URL的方法,需要的朋友可以參考下
    2014-02-02
  • ASP.NET core Web中使用appsettings.json配置文件的方法

    ASP.NET core Web中使用appsettings.json配置文件的方法

    這篇文章主要給大家介紹了在ASP.NET core Web中使用appsettings.json配置文件的方法,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考學(xué)習(xí),下面來一起看看吧。
    2017-04-04
  • ASP.NET中TimeSpan的用法實(shí)例解析

    ASP.NET中TimeSpan的用法實(shí)例解析

    這篇文章主要介紹了ASP.NET中TimeSpan的用法,以實(shí)例的形式具體分析了TimeSpan應(yīng)用中的各種常見常量、字段、屬性與方法等,非常具有參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2014-10-10
  • Entity?Framework使用Fluent?API配置案例

    Entity?Framework使用Fluent?API配置案例

    本文詳細(xì)講解了Entity?Framework使用Fluent?API配置案例的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-03-03
  • ASP.NET Forms身份認(rèn)證

    ASP.NET Forms身份認(rèn)證

    asp.net程序中,用戶可以根據(jù)角色訪問對(duì)應(yīng)頁面以及功能。本文將對(duì)此進(jìn)行介紹,具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • asp.net ListView交替背景顏色實(shí)現(xiàn)代碼

    asp.net ListView交替背景顏色實(shí)現(xiàn)代碼

    在asp.net中ListView的交替背景顏色實(shí)現(xiàn),GridView的處理得較多,ListView可以這樣實(shí)現(xiàn)。
    2010-02-02
  • LINQ 標(biāo)準(zhǔn)查詢操作符

    LINQ 標(biāo)準(zhǔn)查詢操作符

    本文介紹了LINQ標(biāo)準(zhǔn)查詢操作符。沒有這些操作符,LINQ就不會(huì)存在。本文為理解這些操作符的功能提供了很好的基礎(chǔ)。了解它們將會(huì)很有幫助,因?yàn)長(zhǎng)INQ的各種Provider都是基于這些操作符來完成各自豐富的功能。
    2010-02-02
  • ASP.NET?MVC5網(wǎng)站開發(fā)之業(yè)務(wù)邏輯層的架構(gòu)和基本功能(四)

    ASP.NET?MVC5網(wǎng)站開發(fā)之業(yè)務(wù)邏輯層的架構(gòu)和基本功能(四)

    這篇文章主要為大家詳細(xì)介紹了ASP.NET?MVC5網(wǎng)站開發(fā)之業(yè)務(wù)邏輯層的架構(gòu)和基本功能,感興趣的小伙伴們可以參考一下
    2016-08-08
  • VS2019中.NET如何實(shí)現(xiàn)打日志功能

    VS2019中.NET如何實(shí)現(xiàn)打日志功能

    本文主要介紹了VS2019中.NET如何實(shí)現(xiàn)打日志功能,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論