asp.net中用soapheader作验证的使用步骤: 很简单
2015-07-19 23:23
603 查看
Asp.net页面中调用以SOAP头作验证的web services操作步骤:
第一步:用来作SOAP验证的类必须从SoapHeader类派生,类中Public的属性将出现在自动产生XML节点中,即:
<soap:Header>
<UserSoapHeader xmlns="http://tempuri.org/">
<UserName>string</UserName>
<Pwd>string</Pwd>
</UserSoapHeader>
</soap:Header>
public class UserSoapHeader : SoapHeader
{
private string _userName;
private string _pwd;
//public的属性将自动生成xml结点
public string UserName
{
get { return _userName; }
set { _userName = value; }
}
public string Pwd
{
get { return _pwd; }
set { _pwd = value; }
}
}
第二步:
在WebServices服务类中添加一个public的属性(必须public),类型为从UserSoapHeader
/// <summary>
/// WebService 的摘要说明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService : System.Web.Services.WebService
{
//此属性将作为验证属性
//方法的SoapHeaderAttribute中的名称与此变量一致
public UserSoapHeader userHeader;
public WebService()
{
//如果使用设计的组件,请取消注释以下行
//InitializeComponent();
}
[WebMethod]
[SoapHeader("userHeader")]//这里很重要,名称要和定义的验证属性名称一致!
public string HelloWorld()
{
//进入此方法后,userHeader将自动有值
if (userHeader != null)
{
return "this is retVal : " + userHeader.UserName;
}
return " check not successed ";
}
}
第三步:在客户端进行调用:
添加WEB引用
实例化服务类
实例化SOAP头(在客户端将会自动生成作来作验证的属性;该属性类型为:UserSoapHeader;该属性的名称为:UserSoapHeaderValue) ;自动生成的属性生成规则为:验证类型名称+Value;
调用服务提供的方法。
WebService s = new WebService();
UserSoapHeader a = new UserSoapHeader();
a.UserName = "admin";
a.Pwd = "zz";
s.UserSoapHeaderValue = a; //此属性是自动生成的
Response.Write( s.HelloWorld() ); // this is retVal : admin
很简单,完事了!
第一步:用来作SOAP验证的类必须从SoapHeader类派生,类中Public的属性将出现在自动产生XML节点中,即:
<soap:Header>
<UserSoapHeader xmlns="http://tempuri.org/">
<UserName>string</UserName>
<Pwd>string</Pwd>
</UserSoapHeader>
</soap:Header>
public class UserSoapHeader : SoapHeader
{
private string _userName;
private string _pwd;
//public的属性将自动生成xml结点
public string UserName
{
get { return _userName; }
set { _userName = value; }
}
public string Pwd
{
get { return _pwd; }
set { _pwd = value; }
}
}
第二步:
在WebServices服务类中添加一个public的属性(必须public),类型为从UserSoapHeader
/// <summary>
/// WebService 的摘要说明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class WebService : System.Web.Services.WebService
{
//此属性将作为验证属性
//方法的SoapHeaderAttribute中的名称与此变量一致
public UserSoapHeader userHeader;
public WebService()
{
//如果使用设计的组件,请取消注释以下行
//InitializeComponent();
}
[WebMethod]
[SoapHeader("userHeader")]//这里很重要,名称要和定义的验证属性名称一致!
public string HelloWorld()
{
//进入此方法后,userHeader将自动有值
if (userHeader != null)
{
return "this is retVal : " + userHeader.UserName;
}
return " check not successed ";
}
}
第三步:在客户端进行调用:
添加WEB引用
实例化服务类
实例化SOAP头(在客户端将会自动生成作来作验证的属性;该属性类型为:UserSoapHeader;该属性的名称为:UserSoapHeaderValue) ;自动生成的属性生成规则为:验证类型名称+Value;
调用服务提供的方法。
WebService s = new WebService();
UserSoapHeader a = new UserSoapHeader();
a.UserName = "admin";
a.Pwd = "zz";
s.UserSoapHeaderValue = a; //此属性是自动生成的
Response.Write( s.HelloWorld() ); // this is retVal : admin
很简单,完事了!
相关文章推荐
- asp.net 2.0中傻瓜式使用soap header
- asp.net 缓存
- VS2010部署Asp.net程序到本地IIS 7
- (转)ASP.NET前台代码绑定后台变量方法总结
- onClick和onclientclick区别
- Spring基于注解@AspectJ的AOP
- 架构设计(ASP.NET MVC+Knockout+Web API+SignalR)
- ASP.NET MVC 之控制器与视图之间的数据传递
- Asp.Net中WebServices的调用方式
- ASP.net后台弹出消息对话框的方法!【转】
- spring AspectJ的Execution表达式-备忘笔记(转)
- ASP.NET - 缓存(Cache)
- ASP.NET2.0下实现分布式StateServer(状态服务器)
- Asp.Net 4.5网站使用IIS发布 uploadify插件 上传文件大小问题
- asp.net站点报错“对象的当前状态使该操作无效。”的解决办法
- 用 snprintf / asprintf 取代不安全的 sprintf
- C#、ASP.NET、WinForm - 实现邮件发送的功能
- ASP.NET中将声音文件添加到资源中并进行播放的方法
- ASP.NET的Page_Load事件
- B/S在北大青鸟-ASP.NET 总结