BasicAuthorizeAttribute.cs 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6. using System.Web.Http;
  7. namespace ProjectManagementSystem.WebApi.Auth
  8. {
  9. /// <summary>
  10. /// 自定义此特性用于接口的身份验证
  11. /// BasicAuth基本身份验证
  12. /// </summary>
  13. public class BasicAuthorizeAttribute : AuthorizeAttribute
  14. {
  15. //重写基类的验证方式,加入我们自定义的Ticket验证
  16. public override void OnAuthorization(System.Web.Http.Controllers.HttpActionContext actionContext)
  17. {
  18. //从http请求的头里面获取身份验证信息,验证是否是请求发起方的ticket
  19. var authorization = actionContext.Request.Headers.Authorization;
  20. if ((authorization != null) && (authorization.Parameter != null))
  21. {
  22. //解密用户ticket,并校验用户名密码是否匹配
  23. var encryptTicket = authorization.Parameter;
  24. if (ValidateTicket(encryptTicket))
  25. {
  26. base.IsAuthorized(actionContext);
  27. }
  28. else
  29. {
  30. HandleUnauthorizedRequest(actionContext);
  31. }
  32. }
  33. //如果取不到身份验证信息,并且不允许匿名访问,则返回未验证401
  34. else
  35. {
  36. var attributes = actionContext.ActionDescriptor.GetCustomAttributes<AllowAnonymousAttribute>().OfType<AllowAnonymousAttribute>();
  37. bool isAnonymous = attributes.Any(a => a is AllowAnonymousAttribute);
  38. if (isAnonymous) base.OnAuthorization(actionContext);
  39. else HandleUnauthorizedRequest(actionContext);
  40. }
  41. }
  42. //校验用户名密码(正式环境中应该是数据库校验)
  43. private bool ValidateTicket(string encryptTicket)
  44. {
  45. //解密Ticket
  46. //var strTicket = FormsAuthentication.Decrypt(encryptTicket).UserData;
  47. //var strTicket = "";
  48. ////从Ticket里面获取用户名和密码
  49. //var index = strTicket.IndexOf("&");
  50. //string strUser = strTicket.Substring(0, index);
  51. //string strPwd = strTicket.Substring(index + 1);
  52. //解密Ticket
  53. var credentials = Encoding.UTF8.GetString(Convert.FromBase64String(encryptTicket));
  54. var data = credentials.Split(':');
  55. if (data.Length != 2)
  56. {
  57. return false;
  58. }
  59. string strUser = data[0];
  60. string strPwd = data[1];
  61. if (strUser == "admin" && strPwd == "123456")
  62. {
  63. return true;
  64. }
  65. else
  66. {
  67. return false;
  68. }
  69. }
  70. }
  71. }