using System; using System.Collections.Generic; using System.Linq; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using Microsoft.AspNetCore.Authorization; using System.Web; using MySystem.Models; using LitJson; using Library; namespace MySystem.Areas.Api.Controllers.v1 { [Area("Api")] [Route("Api/v1/[controller]/[action]")] public class UploadParamsController : BaseController { public UploadParamsController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting) { } #region 通用-根据Base64返回图片地址 [Authorize] public JsonResult Base64ToPic(string value) { value = DesDecrypt(value); JsonData data = JsonMapper.ToObject(value); Dictionary<string, object> Obj = Base64ToPicDo(value); return Json(new AppResultJson() { Status = "1", Info = "", Data = Obj }); } public Dictionary<string, object> Base64ToPicDo(string value) { JsonData data = JsonMapper.ToObject(value); string Base64 = data["Base64"].ToString(); //图片base64编码 Dictionary<string, object> Obj = new Dictionary<string, object>(); UploadParams query = new UploadParams(); int Id = int.Parse(function.CheckInt(data["Id"].ToString())); query = new UploadParamsService().Query(Id); Obj.Add("PicUrl", ""); //图片地址 return Obj; } #endregion #region 检查签名是否合法,合法返回1,不合法返回提示信息 /// <summary> /// 检查签名是否合法,合法返回1,不合法返回提示信息 /// </summary> /// <param name="value">请求的参数(json字符串)</param> /// <param name="signField">要签名的字段</param> /// <returns></returns> private string CheckSign(string value, string[] signField) { JsonData json = JsonMapper.ToObject(value); Dictionary<string, string> dic = new Dictionary<string, string>(); for (int i = 0; i < signField.Length; i++) { dic.Add(signField[i], json[signField[i]].ToString()); } string sign = json["sign"].ToString(); //客户端签名字符串 return new Sign().sign(dic, sign); } #endregion } }