经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C# » 查看文章
c#中token的使用方法实例
来源:jb51  时间:2022/2/14 11:35:57  对本文有异议

token的存在意义

这是我初略了解的token的存在意义

  • 用户使用用户名密码来请求服务器
  • 服务器进行验证用户的信息
  • 服务器通过验证发送给用户一个token
  • 客户端存储token,并在每次请求时附送上这个token值
  • 服务端验证token值,并返回数据

使用方法

先安装一个JWT,注意NetFramework的版本

创建一个工具类TokenInfo.cs

  1. using JWT;
  2. using JWT.Algorithms;
  3. using JWT.Serializers;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Web;
  7. using System.Web.Script.Serialization;
  8.  
  9. namespace ProjectLYG.Common
  10. {
  11. ? ? public class TokenInfo
  12. ? ? {
  13. ? ? ? ? public TokenInfo()
  14. ? ? ? ? {
  15. ? ? ? ? ? ? UserName = "j";
  16. ? ? ? ? ? ? Pwd = "123456";
  17. ? ? ? ? }
  18. ? ? ? ? public string UserName { get; set; }
  19. ? ? ? ? public string Pwd { get; set; }
  20. ? ? }
  21.  
  22. ? ? public class TokenHelper
  23. ? ? {
  24. ? ? ? ? public static string SecretKey = "bqsid123k12s0h1d3uhf493fh02hdd102h9s3h38ff";//这个服务端加密秘钥 属于私钥
  25. ? ? ? ? private static JavaScriptSerializer myJson = new JavaScriptSerializer();
  26. ? ? ? ? /// <summary>
  27. ? ? ? ? /// 生成Token
  28. ? ? ? ? /// </summary>
  29. ? ? ? ? /// <param name="M"></param>
  30. ? ? ? ? /// <returns></returns>
  31. ? ? ? ? public static string GenToken(TokenInfo M)
  32. ? ? ? ? {
  33. ? ? ? ? ? ? var payload = new Dictionary<string, dynamic>
  34. ? ? ? ? ? ? {
  35. ? ? ? ? ? ? ? ? {"UserName", M.UserName},//用于存放当前登录人账户信息
  36. ? ? ? ? ? ? ? ? {"UserPwd", M.Pwd}//用于存放当前登录人登录密码信息
  37. ? ? ? ? ? ? };
  38. ? ? ? ? ? ? IJwtAlgorithm algorithm = new HMACSHA256Algorithm();
  39. ? ? ? ? ? ? IJsonSerializer serializer = new JsonNetSerializer();
  40. ? ? ? ? ? ? IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();
  41. ? ? ? ? ? ? IJwtEncoder encoder = new JwtEncoder(algorithm, serializer, urlEncoder);
  42. ? ? ? ? ? ? return encoder.Encode(payload, SecretKey);
  43. ? ? ? ? }
  44. ? ? ? ? /// <summary>
  45. ? ? ? ? /// 验证Token
  46. ? ? ? ? /// </summary>
  47. ? ? ? ? /// <returns></returns>
  48. ? ? ? ? public static string DecodeToken()
  49. ? ? ? ? {
  50. ? ? ? ? ? ? //获取request中的token
  51. ? ? ? ? ? ? string token = HttpContext.Current.Request.Headers["Authorization"];
  52. ? ? ? ? ? ? //去掉前面的Bearer
  53. ? ? ? ? ? ? if (token != null && token.StartsWith("Bearer"))
  54. ? ? ? ? ? ? ? ? token = token.Substring("Bearer ".Length).Trim();
  55. ? ? ? ? ? ? try
  56. ? ? ? ? ? ? {
  57. ? ? ? ? ? ? ? ? var json = GetTokenJson(token);
  58. ? ? ? ? ? ? ? ? TokenInfo info = myJson.Deserialize<TokenInfo>(json);
  59. ? ? ? ? ? ? ? ? return "Token is true";
  60. ? ? ? ? ? ? }
  61. ? ? ? ? ? ? catch (TokenExpiredException)
  62. ? ? ? ? ? ? {
  63. ? ? ? ? ? ? ? ? return "Token has expired";
  64. ? ? ? ? ? ? }
  65. ? ? ? ? ? ? catch (SignatureVerificationException)
  66. ? ? ? ? ? ? {
  67. ? ? ? ? ? ? ? ? return "Token has invalid signature";
  68. ? ? ? ? ? ? }
  69. ? ? ? ? }
  70.  
  71. ? ? ? ? public static string GetTokenJson(string token)
  72. ? ? ? ? {
  73. ? ? ? ? ? ? try
  74. ? ? ? ? ? ? {
  75. ? ? ? ? ? ? ? ? IJsonSerializer serializer = new JsonNetSerializer();
  76. ? ? ? ? ? ? ? ? IDateTimeProvider provider = new UtcDateTimeProvider();
  77. ? ? ? ? ? ? ? ? IJwtValidator validator = new JwtValidator(serializer, provider);
  78. ? ? ? ? ? ? ? ? IBase64UrlEncoder urlEncoder = new JwtBase64UrlEncoder();
  79. ? ? ? ? ? ? ? ? IJwtDecoder decoder = new JwtDecoder(serializer, validator, urlEncoder);
  80. ? ? ? ? ? ? ? ? var json = decoder.Decode(token, SecretKey, verify: true);
  81. ? ? ? ? ? ? ? ? return json;
  82. ? ? ? ? ? ? }
  83. ? ? ? ? ? ? catch (Exception)
  84. ? ? ? ? ? ? {
  85. ? ? ? ? ? ? ? ? throw;
  86. ? ? ? ? ? ? }
  87. ? ? ? ? }
  88. ? ? }
  89. }

使用方法

  1. ??? ??? ??? ??? ?//生成Token
  2. ? ? ? ? ? ? ? ? TokenInfo tokenInfo = new TokenInfo();
  3. ? ? ? ? ? ? ? ? tokenInfo.Pwd = password;
  4. ? ? ? ? ? ? ? ? tokenInfo.UserName = tel;
  5. ? ? ? ? ? ? ? ? string token = TokenHelper.GenToken(tokenInfo);
  6. ? ? ? ? ? ? ? ? ........
  7. ? ? ? ? ? ? ? ? ?//token验证
  8. ? ? ? ? ? ? ? ? string tokenInfo = TokenHelper.DecodeToken();
  9. ? ? ? ? ? ? ? ? ........

工具类已将返回的Request的token值提取出,无须传值

到此这篇关于c#中token的使用方法实例的文章就介绍到这了,更多相关c# token内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号