安全性

ASP.NET WebService 认证
•完全适用ASP.NET的认证机制
–可以使用FormsAuthentication
•WebService方法可以操作Cookie
–Impersonation
–PrincipalPermission


aspx
    <form id="form1" runat="server">
        
<asp:ScriptManager runat="server" ID="ScriptManager1" ScriptMode="Debug">
            
<Services>
                
<asp:ServiceReference Path="Services/SecurityService.asmx" InlineScript="true" />
            
</Services>
        
</asp:ScriptManager>    
        
        
<input type="button" value="Call" onclick="call()" />
    
        
<script language="javascript" type="text/javascript">
            function call()
            {
                SecurityService.HelloWorld(onSucceeded);
            }
            
            function onSucceeded(result)
            {
                alert(result);
            }
        
</script>    
    
</form>

cs
    protected void Page_Load(object sender, EventArgs e)
    {
        FormsAuthentication.SetAuthCookie(
"Jeffrey Zhao"false);
    }
如果不加上这一句,WebService就会跑出异常“Please log in first

SecurityService.asmx
<%@ WebService Language="C#" Class="SecurityService" %>

using System;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Web.Script.Services;

[WebService(Namespace 
= "http://tempuri.org/")]
[WebServiceBinding(ConformsTo 
= WsiProfiles.BasicProfile1_1)]
[ScriptService]
public class SecurityService : System.Web.Services.WebService
{
    [WebMethod]
    
public string HelloWorld()
    {
        
if (!HttpContext.Current.User.Identity.IsAuthenticated)
        {
            
throw new ApplicationException("Please log in first.");
        }
        
        
return "Hello, " + HttpContext.Current.User.Identity.Name;
    }
    
}

转载于:https://www.cnblogs.com/timy/archive/2008/04/30/1178274.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值