/* * 上传配置项 */ 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 UploadParamsController : BaseController { public UploadParamsController(IHttpContextAccessor accessor, ILogger logger, IOptions setting) : base(accessor, logger, setting) { OtherMySqlConn.connstr = ConfigurationManager.AppSettings["BsSqlConnStr"].ToString(); } #region 上传配置项列表 /// /// 根据条件查询上传配置项列表 /// /// public IActionResult Index(UploadParams data, string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; string Condition = ""; Condition += "TableName:\"" + data.TableName + "\","; Condition += "ColumnName:\"" + data.ColumnName + "\","; Condition += "ColumnEnName:\"" + data.ColumnEnName + "\","; if (!string.IsNullOrEmpty(Condition)) { Condition = Condition.TrimEnd(','); Condition = ", where: {" + Condition + "}"; } ViewBag.Condition = Condition; return View(); } #endregion #region 根据条件查询上传配置项列表 /// /// 上传配置项列表 /// /// public JsonResult IndexData(UploadParams data, int page = 1, int limit = 30) { Dictionary Fields = new Dictionary(); Fields.Add("TableName", "2"); //表名 Fields.Add("ColumnName", "2"); //字段名 Fields.Add("ColumnEnName", "2"); //字段英文明 Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("UploadParams", Fields, "Id desc", "0", page, limit); //List> diclist = obj["data"] as List>; //foreach (Dictionary dic in diclist) //{ //} return Json(obj); } #endregion #region 增加上传配置项 /// /// 增加或修改上传配置项信息 /// /// public IActionResult Add(string right) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; return View(); } #endregion #region 增加上传配置项 /// /// 增加或修改上传配置项信息 /// /// [HttpPost] public string Add(UploadParams data) { Dictionary Fields = new Dictionary(); Fields.Add("TableName", data.TableName); //表名 Fields.Add("TableEnName", data.TableEnName); Fields.Add("ColumnName", data.ColumnName); //字段名 Fields.Add("ColumnEnName", data.ColumnEnName); //字段英文明 Fields.Add("ParamString", data.ParamString); //参数 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Add("UploadParams", Fields, 0); AddSysLog(data.Id.ToString(), "UploadParams", "add"); bsdb.SaveChanges(); RedisDbconn.Instance.Set("btn:" + function.MD5_16(data.TableEnName + data.ColumnEnName), data.ParamString); return "success"; } #endregion #region 修改上传配置项 /// /// 增加或修改上传配置项信息 /// /// public IActionResult Edit(string right, int Id = 0) { ViewBag.RightInfo = RightInfo; ViewBag.right = right; UploadParams editData = bsdb.UploadParams.FirstOrDefault(m => m.Id == Id) ?? new UploadParams(); ViewBag.data = editData; return View(); } #endregion #region 修改上传配置项 /// /// 增加或修改上传配置项信息 /// /// [HttpPost] public string Edit(UploadParams data) { Dictionary Fields = new Dictionary(); Fields.Add("TableName", data.TableName); //表名 Fields.Add("TableEnName", data.TableEnName); Fields.Add("ColumnName", data.ColumnName); //字段名 Fields.Add("ColumnEnName", data.ColumnEnName); //字段英文明 Fields.Add("ParamString", data.ParamString); //参数 Fields.Add("SeoTitle", data.SeoTitle); Fields.Add("SeoKeyword", data.SeoKeyword); Fields.Add("SeoDescription", data.SeoDescription); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("UploadParams", Fields, data.Id); AddSysLog(data.Id.ToString(), "UploadParams", "update"); bsdb.SaveChanges(); RedisDbconn.Instance.Set("btn:" + function.MD5_16(data.TableEnName + data.ColumnEnName), data.ParamString); return "success"; } #endregion #region 删除上传配置项信息 /// /// 删除上传配置项信息 /// /// public string Delete(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UploadParams", "del"); foreach (string subid in idlist) { int id = int.Parse(subid); new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Delete("UploadParams", id); } bsdb.SaveChanges(); return "success"; } #endregion #region 开启 /// /// 开启 /// /// public string Open(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UploadParams", "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("UploadParams", Fields, id); } bsdb.SaveChanges(); return "success"; } #endregion #region 关闭 /// /// 关闭 /// /// public string Close(string Id) { string[] idlist = Id.Split(new char[] { ',' }); AddSysLog(Id, "UploadParams", "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("UploadParams", Fields, id); } bsdb.SaveChanges(); return "success"; } #endregion #region 排序 /// /// 排序 /// /// public string Sort(int Id, int Sort) { new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Sort("UploadParams", Sort, Id); AddSysLog(Id.ToString(), "UploadParams", "sort"); 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]; bsdb.UploadParams.Add(new UploadParams() { CreateDate = DateTime.Now, UpdateDate = DateTime.Now, }); bsdb.SaveChanges(); } AddSysLog("0", "UploadParams", "Import"); return "success"; } #endregion #region 导出Excel /// /// 导出Excel /// /// public JsonResult ExportExcel(UploadParams data) { Dictionary Fields = new Dictionary(); Fields.Add("TableName", "2"); //表名 Fields.Add("ColumnName", "2"); //字段名 Fields.Add("ColumnEnName", "2"); //字段英文明 Dictionary obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("UploadParams", Fields, "Id desc", "0", 1, 20000, "", "", 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(); result.Add("Fields", ReturnFields); AddSysLog("0", "UploadParams", "ExportExcel"); return Json(result); } #endregion #region 生成配置 /// /// 生成配置 /// /// public string MakeParams() { AddSysLog(0, "UploadParams", "MakeParam"); List paramlist = bsdb.UploadParams.ToList(); foreach (UploadParams param in paramlist) { RedisDbconn.Instance.Set("btn:" + function.MD5_16(param.TableEnName + param.ColumnEnName), param.ParamString); } return "success"; } #endregion } }