UsersController.cs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using Microsoft.AspNetCore.Mvc;
  5. using Microsoft.AspNetCore.Http;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.Extensions.Options;
  8. using Microsoft.AspNetCore.Authorization;
  9. using System.Web;
  10. using MySystem.Models;
  11. using LitJson;
  12. using Library;
  13. namespace MySystem.Areas.Api.Controllers.v1
  14. {
  15. [Area("Api")]
  16. [Route("Api/v1/[controller]/[action]")]
  17. public class UsersController : BaseController
  18. {
  19. public UsersController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  20. {
  21. }
  22. #region 通用-获取Token
  23. // [Authorize]
  24. public JsonResult GetToken(string value)
  25. {
  26. // value = DesDecrypt(value);
  27. function.WriteLog(DateTime.Now.ToString() + "\n" + value + "\n\n", "通用-获取Token");
  28. JsonData data = JsonMapper.ToObject(value);
  29. string AppId = data["AppId"].ToString(); //AppId
  30. string AppSecret = data["AppSecret"].ToString(); //AppSecret
  31. Dictionary<string, object> Obj = new Dictionary<string, object>();
  32. Users query = db.Users.FirstOrDefault(m => m.AppId == AppId && m.AppSecret == AppSecret);
  33. if(query != null)
  34. {
  35. Obj.Add("Token", function.MD5_32(AppId + "G9&E@952")); //用户令牌
  36. }
  37. else
  38. {
  39. return Json(new AppResultJson() { Status = "-1", Info = "获取失败,AppId或AppSecret有误", Data = Obj });
  40. }
  41. return Json(new AppResultJson() { Status = "1", Info = "", Data = Obj });
  42. }
  43. #endregion
  44. #region 检查签名是否合法,合法返回1,不合法返回提示信息
  45. /// <summary>
  46. /// 检查签名是否合法,合法返回1,不合法返回提示信息
  47. /// </summary>
  48. /// <param name="value">请求的参数(json字符串)</param>
  49. /// <param name="signField">要签名的字段</param>
  50. /// <returns></returns>
  51. private string CheckSign(string value, string[] signField)
  52. {
  53. JsonData json = JsonMapper.ToObject(value);
  54. Dictionary<string, string> dic = new Dictionary<string, string>();
  55. for (int i = 0; i < signField.Length; i++)
  56. {
  57. dic.Add(signField[i], json[signField[i]].ToString());
  58. }
  59. string sign = json["sign"].ToString(); //客户端签名字符串
  60. return new Sign().sign(dic, sign);
  61. }
  62. #endregion
  63. }
  64. }