/* * App版本管理 */ using System; using System.Web; using System.Collections.Generic; using System.Diagnostics; using System.Linq; using System.Threading.Tasks; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Http; using Microsoft.Extensions.Logging; using Microsoft.Extensions.Options; using MySystem.BsModels; using Library; using LitJson; using MySystemLib; namespace MySystem.Areas.Admin.Controllers { [Area("Admin")] [Route("Admin/[controller]/[action]")] public class AppVersionController : BaseController { public AppVersionController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["BsSqlConnStr"].ToString(); } #region App版本管理列表 /// /// 根据条件查询App版本管理列表 /// /// public IActionResult Index(AppVersion data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; string Condition = ""; if (!string.IsNullOrEmpty(Condition)) { Condition = Condition.TrimEnd(','); Condition = ", where: {" + Condition + "}"; } ViewBag.Condition = Condition; return View(); } #endregion #region 根据条件查询App版本管理列表 /// /// App版本管理列表 /// /// public JsonResult IndexData(AppVersion data, string Kind = "default", int page = 1, int limit = 30) { Dictionary Fields = new Dictionary(); string condition = " and SeoKeyword='" + Kind + "'"; Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("AppVersion", Fields, "Id desc", "0", page, limit, condition); List> diclist = obj["data"] as List>; foreach (Dictionary dic in diclist) { dic["Status"] = dic["Status"].ToString() == "1" ? "开启" : "关闭"; } return Json(obj); } #endregion #region 增加App版本管理 /// /// 增加或修改App版本管理信息 /// /// public IActionResult Add(string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 增加App版本管理 /// /// 增加或修改App版本管理信息 /// /// [HttpPost] public string Add(AppVersion data) { Dictionary Fields = new Dictionary(); Fields.Add("TerminalKind", data.TerminalKind); //终端类型 Fields.Add("VersionNum", data.VersionNum); //版本号 Fields.Add("Title", data.Title); //标题 Fields.Add("Info", data.Info); //更新信息 Fields.Add("ConfirmText", data.ConfirmText); //确定按钮文字 Fields.Add("CancelText", data.CancelText); //取消按钮文字 Fields.Add("DownloadUrl", data.DownloadUrl); //更新地址 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Add("AppVersion", Fields, 0); AddSysLog(data.Id.ToString(), "AppVersion", "add"); bsdb.SaveChanges(); SetRedis(); return "success"; } #endregion #region 修改App版本管理 /// /// 增加或修改App版本管理信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; AppVersion editData = bsdb.AppVersion.FirstOrDefault(m => m.Id == Id) ?? new AppVersion(); ViewBag.data = editData; return View(); } #endregion #region 修改App版本管理 /// /// 增加或修改App版本管理信息 /// /// [HttpPost] public string Edit(AppVersion data) { Dictionary Fields = new Dictionary(); Fields.Add("TerminalKind", data.TerminalKind); //终端类型 Fields.Add("VersionNum", data.VersionNum); //版本号 Fields.Add("Title", data.Title); //标题 Fields.Add("Info", data.Info); //更新信息 Fields.Add("ConfirmText", data.ConfirmText); //确定按钮文字 Fields.Add("CancelText", data.CancelText); //取消按钮文字 Fields.Add("DownloadUrl", data.DownloadUrl); //更新地址 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("AppVersion", Fields, data.Id); AddSysLog(data.Id.ToString(), "AppVersion", "update"); bsdb.SaveChanges(); SetRedis(); return "success"; } #endregion #region 删除App版本管理信息 /// /// 删除App版本管理信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "AppVersion", "del"); foreach (string subid in idlist) { int id = int.Parse(subid); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Delete("AppVersion", id); } bsdb.SaveChanges(); SetRedis(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "AppVersion", "open"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 1); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("AppVersion", Fields, id); } bsdb.SaveChanges(); SetRedis(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "AppVersion", "close"); foreach (string subid in idlist) { int id = int.Parse(subid); Dictionary Fields = new Dictionary(); Fields.Add("Status", 0); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("AppVersion", Fields, id); } bsdb.SaveChanges(); SetRedis(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Sort("AppVersion", Sort, Id); AddSysLog(Id.ToString(), "AppVersion", "sort"); SetRedis(); return "success"; } #endregion #region 导入数据 /// /// 导入数据 /// /// public string Import(string ExcelData) { ExcelData = HttpUtility.UrlDecode(ExcelData); JsonData list = JsonMapper.ToObject(ExcelData); for (int i = 1; i < list.Count; i++) { JsonData dr = list[i]; string TerminalKind = dr["终端类型"].ToString(); string VersionNum = dr["版本号"].ToString(); string Title = dr["标题"].ToString(); string Info = dr["更新信息"].ToString(); string ConfirmText = dr["确定按钮文字"].ToString(); string CancelText = dr["取消按钮文字"].ToString(); string DownloadUrl = dr["更新地址"].ToString(); bsdb.AppVersion.Add(new AppVersion() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, TerminalKind = TerminalKind, //终端类型 VersionNum = VersionNum, //版本号 Title = Title, //标题 Info = Info, //更新信息 ConfirmText = ConfirmText, //确定按钮文字 CancelText = CancelText, //取消按钮文字 DownloadUrl = DownloadUrl, //更新地址 }); bsdb.SaveChanges(); } AddSysLog("0", "AppVersion", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(AppVersion data) { Dictionary Fields = new Dictionary(); Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("AppVersion", Fields, "Id desc", "0", 1, 20000, "", "TerminalKind,Version,Title,Info,ConfirmText,CancelText,DownloadUrl", false); List> diclist = obj["data"] as List>; Dictionary result = new Dictionary(); result.Add("Status", "1"); result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx"); result.Add("Obj", diclist); Dictionary ReturnFields = new Dictionary(); ReturnFields.Add("TerminalKind", "终端类型"); ReturnFields.Add("Version", "版本号"); ReturnFields.Add("Title", "标题"); ReturnFields.Add("Info", "更新信息"); ReturnFields.Add("ConfirmText", "确定按钮文字"); ReturnFields.Add("CancelText", "取消按钮文字"); ReturnFields.Add("DownloadUrl", "更新地址"); result.Add("Fields", ReturnFields); AddSysLog("0", "AppVersion", "ExportExcel"); return Json(result); } #endregion #region 同步数据到redis public string SyncAll(string Kind = "default") { // List appvers = bsdb.AppVersion.Where(m => m.SeoKeyword == Kind).ToList(); // RedisDbconn.Instance.Clear("AppVersion:" + Kind + ""); // RedisDbconn.Instance.AddList("AppVersion:" + Kind + "", appvers.ToArray()); SetRedis(); return "success"; } #endregion #region 设置缓存 private void SetRedis() { int count = bsdb.AppVersion.Count(); if(count < 1) { return; } List Roles = new List(); Roles.Add("consumer"); Roles.Add("merchant"); Roles.Add("creater"); Roles.Add("cyb"); foreach (string Role in Roles) { List list = bsdb.AppVersion.Where(m => m.SeoKeyword == Role).OrderByDescending(m => m.Sort).ThenByDescending(m => m.Id).ToList(); RedisDbconn.Instance.AddList("AppVersion", list.ToArray()); AppVersion ver = list.Where(m => m.TerminalKind == "ios").FirstOrDefault(); if (ver != null) { RedisDbconn.Instance.Set("AppVersion:Last:" + Role + ":ios", ver); } ver = list.Where(m => m.TerminalKind == "android").FirstOrDefault(); if (ver != null) { RedisDbconn.Instance.Set("AppVersion:Last:" + Role + ":android", ver); } } } #endregion } }