最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

ASP.NET中Webservice安全 实现访问权限控制

来源:动视网 责编:小采 时间:2020-11-27 22:37:06
文档

ASP.NET中Webservice安全 实现访问权限控制

ASP.NET中Webservice安全 实现访问权限控制:一、 概述: Web Services是由企业发布的完成其特定商务需求的在线应用服务,其他公司或应用软件能够通过Internet来访问并使用这项在线服务。它逻辑性的为 其他应用程序提供数据与服务.各应用程序通过网络协议和规定的一些标准数据格式(Http,XML,S
推荐度:
导读ASP.NET中Webservice安全 实现访问权限控制:一、 概述: Web Services是由企业发布的完成其特定商务需求的在线应用服务,其他公司或应用软件能够通过Internet来访问并使用这项在线服务。它逻辑性的为 其他应用程序提供数据与服务.各应用程序通过网络协议和规定的一些标准数据格式(Http,XML,S


一、 概述:

  Web Services是由企业发布的完成其特定商务需求的在线应用服务,其他公司或应用软件能够通过Internet来访问并使用这项在线服务。它逻辑性的为 其他应用程序提供数据与服务.各应用程序通过网络协议和规定的一些标准数据格式(Http,XML,Soap)来访问Web Service,通过Web Service内部执行得到所需结果。由于它通过internet进行调用,必然存在网络用户都可以调用的安全问题。如何实现webservice的访问 权限,是使用webservice用户使用面临重要的问题,下文就给两种方案,从浅到深解决上面问题。

二、基于“soapheader” 特性的简单方法

1." soapheader" 概述  

SOAP 标头提供了一种方法,用于将数据传递到 XML Web services 方法或从 XML Web services 方法传递数据,条件是该数据不直接与 XML Web services 方法的主功能相关。 多数情况下用来传递用户身份验证信息,当然它的作用远不止如此,有待于在实际应用中发掘。

2.soapheader实现用户身份验证代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
namespace UserCenter
{
 public class MySoapHeader :SoapHeader
 {
 public string UserName
 {
 get;
 set;
 }
 public string PWD
 {
 get;
 set;
 }
 }
 /// <summary>
 /// MyMath 的摘要说明
 /// </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 MyMath : System.Web.Services.WebService
 {
 public MySoapHeader sHeader;
 [WebMethod]
 public string HelloWorld()
 {
 return "Hello World";
 }
 [WebMethod]
 [SoapHeader("sHeader")]
 public string add(int x, int y)
 {
 if (sHeader.UserName == "test" && sHeader.PWD == "test")
 {
 return (x + y).ToString();
 }
 else
 {
 return null;
 }
 }
 }
}

3.缺点分析:

(1)服务逻辑和用户权限验证逻辑混和,加大程序理解复杂度。
(2)权限逻辑重用性不高

二、基于“SoapExtensionAttribute” 特性的方法

1.SoapExtensionAttribute与SoapExtension概述

SoapExtension和SoapExtensio。Attribute两个类用于控制webservice序列化和反序列化的一般过程,可对webservice进行压缩和日志等功能进行控制.

2.实现代码 

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.Services;

using System.Web.Services.Protocols;

namespace XMLClass1.class15.content

{

 [AttributeUsage(AttributeTargets.Method)]

 public class MyExtensionAttribute : SoapExtensionAttribute

 {

 int _priority = 1;

 public override int Priority

 {

 get { return _priority; }

 set { _priority = value; }

 }

 public override Type ExtensionType

 {

 get { return typeof(MyExtension); }

 }

 }

 public class MyExtension : SoapExtension

 {

 //这个override的方法会被调用四次

 //分别是SoapMessageStage BeforeSerialize,AfterSerialize,BeforeDeserialize,AfterDeserialize

 public override void ProcessMessage(SoapMessage message)

 {

 if (message.Stage == SoapMessageStage.AfterDeserialize)//反序列化之后处理

 {

 bool check = false;

 foreach (SoapHeader header in message.Headers)

 {

 if (header is MySoapHeader)

 {

 MySoapHeader myHeader = (MySoapHeader)header;

 if (myHeader.Name == "admin" || myHeader.PassWord == "admin")

 {

 check = true;

 break;

 }

 }

 }

 if (!check)

 throw new SoapHeaderException("认证失败", SoapException.ClientFaultCode);

 }

 }

 public override Object GetInitializer(Type type)

 {

 return GetType();
 }

 public override Object GetInitializer(LogicalMethodInfo info, SoapExtensionAttribute attribute)

 {

 return null;

 }

 public override void Initialize(Object initializer)

 {

 }

 }

 public class MySoapHeader : SoapHeader

 {

 string _name;

 string _passWord;

 public string Name

 {

 get { return _name; }

 set { _name = value; }

 }

 public string PassWord

 {

 get { return _passWord; }

 set { _passWord = value; }

 }

 }

 /// <summary>

 /// headersoap2 的摘要说明

 /// </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 headersoap2 : System.Web.Services.WebService

 {

 public MySoapHeader header;

 [WebMethod]

 [MyExtensionAttribute]

 [SoapHeader("header", Direction = SoapHeaderDirection.In)]

 public string CheckHeader()

 {

 //业务逻辑.

 return "Something done";

 }

 }
}

文档

ASP.NET中Webservice安全 实现访问权限控制

ASP.NET中Webservice安全 实现访问权限控制:一、 概述: Web Services是由企业发布的完成其特定商务需求的在线应用服务,其他公司或应用软件能够通过Internet来访问并使用这项在线服务。它逻辑性的为 其他应用程序提供数据与服务.各应用程序通过网络协议和规定的一些标准数据格式(Http,XML,S
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top