1- 登录获取token data:image/s3,"s3://crabby-images/93643/93643b6300b384a46e8b95d2f9709e92ea88cb86" alt="在这里插入图片描述"
[HttpPost]
[CustomAllowAnonymousAttribute]
public string LoginGetToken(string account, string password)
{
if ("admin".Equals(account) && "123456".Equals(password))
{
FormsAuthenticationTicket ticketObject = new FormsAuthenticationTicket(0, account
, DateTime.Now, DateTime.Now.AddHours(1), true, string.Format("{0}&{1}", account, password)
, FormsAuthentication.FormsCookiePath);
var result = new
{
result = true,
ticket = FormsAuthentication.Encrypt(ticketObject)
};
return JsonConvert.SerializeObject(result);
}
else
{
var result = new { result = false };
return JsonConvert.SerializeObject(result);
}
}
我这里案例是默认的用admin账号,正常开发过程中需要去数据库读取
2-解密验证 data:image/s3,"s3://crabby-images/610c3/610c397c2798bb5c928cc2946015a3db31cdf9d1" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c8c67/c8c67bb4cc7a7d91af086b8f20256c5ffd27e09c" alt="在这里插入图片描述"
public class CustomBasicAuthorizeAttribute : AuthorizeAttribute
{
public override void OnAuthorization(HttpActionContext actionContext)
{
if (actionContext.ActionDescriptor.GetCustomAttributes<CustomAllowAnonymousAttribute>().FirstOrDefault() != null)
{
return;
}
else
{
var authorization = actionContext.Request.Headers.Authorization;
if (authorization == null)
{
throw new HttpResponseException(System.Net.HttpStatusCode.Unauthorized);
}
else
{
if (ValidateTicket(authorization.Parameter))
{
return;
}
else
{
throw new HttpResponseException(System.Net.HttpStatusCode.Unauthorized);
}
}
}
}
private bool ValidateTicket(string encryptTicket)
{
if (string.IsNullOrEmpty(encryptTicket)) return false;
try
{
var newTicket = FormsAuthentication.Decrypt(encryptTicket).UserData;
return string.Equals(newTicket, string.Format("{0}&{1}", "admin", "123456"));
}
catch (Exception e)
{
return false;
}
}
}
3-在配置文件中全局注册 data:image/s3,"s3://crabby-images/5561f/5561f5c29e1d614591b7b94188cda75a1a43d218" alt="在这里插入图片描述"
public static class WebApiConfig
{
public static void Register(HttpConfiguration config)
{
config.Filters.Add(new CustomBasicAuthorizeAttribute());
}
}
4-新建特性自定义类 继承Attribute就可以无需其他操作 目的是在全局注册的情况下 有这个标记就不去走校验方法 data:image/s3,"s3://crabby-images/da14b/da14b8b165dc0ba978ea87faa0618a8e4cf41d91" alt="在这里插入图片描述"
public class CustomAllowAnonymousAttribute:Attribute
{
}
|