尝试将服务引用添加到我的Windows 8应用程序中。但asmx文件位于具有特定角色的登录用户可以查看的文件夹中。像受保护的文件夹一样,我也在使用网站的asp.net会员提供商。如何添加此引用或对其进行身份验证?
感谢。
答案 0 :(得分:2)
有一种更简单的方法可以授权您的服务用户,这可以解决您的一些问题。
首先,将您的服务放在公共文件夹中,完全没有授权。这将允许您从Windows 8应用程序添加引用,没有任何问题。
然后,在您的服务中,创建一种方法来验证您的用户:
public bool Login( string UserName, string Pwd )
{
// validate the user and create the forms cookie upon succesfull validaition
if ( IsValid( UserName, Pwd ) )
{
FormsAuthenticationTicket ticket = new FormsAuthenticationTicket( ... );
string CookieName = FOrmsAuthentication.FormsCookieName;
string CookieValue = ticket.Encrypt();
this.Response.Cookies.Add( new HttpCookie( CookieName, CookieValue ) );
}
}
此公共方法将是Windows 8应用程序应调用的第一种方法。
然后使用PrincipalPermission
属性保护所有其他服务方法:
[PrincipalPermission( Roles="Admin, User" )]
public TheMethodForAdminOrUser()
{
// do whatever you want
}
属性将保护您的服务方法的调用,以便只有通过Login
方法的有效调用进行身份验证的用户才能访问您的服务。