SystemSetController.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384
  1. /*
  2. * 系统设置
  3. */
  4. using System;
  5. using System.Web;
  6. using System.Collections.Generic;
  7. using System.Diagnostics;
  8. using System.Linq;
  9. using System.Threading.Tasks;
  10. using Microsoft.AspNetCore.Mvc;
  11. using Microsoft.AspNetCore.Http;
  12. using Microsoft.Extensions.Logging;
  13. using Microsoft.Extensions.Options;
  14. using MySystem.BsModels;
  15. using Library;
  16. using LitJson;
  17. using MySystemLib;
  18. namespace MySystem.Areas.Admin.Controllers
  19. {
  20. [Area("Admin")]
  21. [Route("Admin/[controller]/[action]")]
  22. public class SystemSetController : BaseController
  23. {
  24. public SystemSetController(IHttpContextAccessor accessor, ILogger<BaseController> logger, IOptions<Setting> setting) : base(accessor, logger, setting)
  25. {
  26. OtherMySqlConn.connstr = ConfigurationManager.AppSettings["BsSqlConnStr"].ToString();
  27. }
  28. #region 系统设置列表
  29. /// <summary>
  30. /// 根据条件查询系统设置列表
  31. /// </summary>
  32. /// <returns></returns>
  33. public IActionResult Index(SystemSet data, string right)
  34. {
  35. ViewBag.RightInfo = RightInfo;
  36. ViewBag.right = right;
  37. string Condition = "";
  38. Condition += "WebUrl:\"" + data.WebUrl + "\",";
  39. Condition += "WebName:\"" + data.WebName + "\",";
  40. if (!string.IsNullOrEmpty(Condition))
  41. {
  42. Condition = Condition.TrimEnd(',');
  43. Condition = ", where: {" + Condition + "}";
  44. }
  45. ViewBag.Condition = Condition;
  46. return View();
  47. }
  48. #endregion
  49. #region 根据条件查询系统设置列表
  50. /// <summary>
  51. /// 系统设置列表
  52. /// </summary>
  53. /// <returns></returns>
  54. public JsonResult IndexData(SystemSet data, int page = 1, int limit = 30)
  55. {
  56. Dictionary<string, string> Fields = new Dictionary<string, string>();
  57. Fields.Add("WebUrl", "2"); //网站地址
  58. Fields.Add("WebName", "2"); //网站名称
  59. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("SystemSet", Fields, "Id desc", "False", page, limit);
  60. //List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  61. //foreach (Dictionary<string, object> dic in diclist)
  62. //{
  63. //}
  64. return Json(obj);
  65. }
  66. #endregion
  67. #region 增加系统设置
  68. /// <summary>
  69. /// 增加或修改系统设置信息
  70. /// </summary>
  71. /// <returns></returns>
  72. public IActionResult Add()
  73. {
  74. ViewBag.right = _accessor.HttpContext.Request.Query["right"];
  75. return View();
  76. }
  77. #endregion
  78. #region 增加系统设置
  79. /// <summary>
  80. /// 增加或修改系统设置信息
  81. /// </summary>
  82. /// <returns></returns>
  83. [HttpPost]
  84. public string Add(SystemSet data)
  85. {
  86. Dictionary<string, object> Fields = new Dictionary<string, object>();
  87. Fields.Add("WebUrl", data.WebUrl); //网站地址
  88. Fields.Add("WebName", data.WebName); //网站名称
  89. Fields.Add("IndexKeyword", data.IndexKeyword); //首页关键词
  90. Fields.Add("IndexDescription", data.IndexDescription); //首页简介
  91. Fields.Add("UploadExt", data.UploadExt); //允许上传类型
  92. Fields.Add("UploadMaxSize", data.UploadMaxSize); //允许最大上传
  93. Fields.Add("UploadAutoZoom", data.UploadAutoZoom); //自动缩略图
  94. Fields.Add("UploadAutoZoomWidth", data.UploadAutoZoomWidth); //自动缩略图宽
  95. Fields.Add("UploadAutoZoomHeight", data.UploadAutoZoomHeight); //自动缩略图高
  96. Fields.Add("UploadAutoWater", data.UploadAutoWater); //自动水印
  97. Fields.Add("UploadWaterPosition", data.UploadWaterPosition); //水印位置
  98. Fields.Add("UploadWaterPath", data.UploadWaterPath); //水印图片
  99. Fields.Add("RightInfo", data.RightInfo); //版权信息
  100. Fields.Add("Address", data.Address); //企业地址
  101. Fields.Add("Phone", data.Phone); //联系电话
  102. Fields.Add("WebStatCode", data.WebStatCode); //网站统计代码
  103. Fields.Add("Logo", data.Logo); //Logo图片
  104. int Id = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Add("SystemSet", Fields, 0);
  105. AddSysLog(data.Id.ToString(), "SystemSet", "add");
  106. bsdb.SaveChanges();
  107. return "success";
  108. }
  109. #endregion
  110. #region 修改系统设置
  111. /// <summary>
  112. /// 增加或修改系统设置信息
  113. /// </summary>
  114. /// <returns></returns>
  115. public IActionResult Edit(int Id = 0)
  116. {
  117. ViewBag.right = _accessor.HttpContext.Request.Query["right"];
  118. SystemSet editData = bsdb.SystemSet.FirstOrDefault() ?? new SystemSet();
  119. ViewBag.data = editData;
  120. return View();
  121. }
  122. #endregion
  123. #region 修改系统设置
  124. /// <summary>
  125. /// 增加或修改系统设置信息
  126. /// </summary>
  127. /// <returns></returns>
  128. [HttpPost]
  129. public string Edit(SystemSet data)
  130. {
  131. Dictionary<string, object> Fields = new Dictionary<string, object>();
  132. Fields.Add("WebUrl", data.WebUrl); //网站地址
  133. Fields.Add("WebName", data.WebName); //网站名称
  134. Fields.Add("IndexKeyword", data.IndexKeyword); //首页关键词
  135. Fields.Add("IndexDescription", data.IndexDescription); //首页简介
  136. Fields.Add("UploadExt", data.UploadExt); //允许上传类型
  137. Fields.Add("UploadMaxSize", data.UploadMaxSize); //允许最大上传
  138. Fields.Add("UploadAutoZoom", data.UploadAutoZoom); //自动缩略图
  139. Fields.Add("UploadAutoZoomWidth", data.UploadAutoZoomWidth); //自动缩略图宽
  140. Fields.Add("UploadAutoZoomHeight", data.UploadAutoZoomHeight); //自动缩略图高
  141. Fields.Add("UploadAutoZoomQuality", data.UploadAutoZoomQuality); //自动缩略图质量
  142. Fields.Add("UploadAutoWater", data.UploadAutoWater); //自动水印
  143. Fields.Add("UploadWaterPosition", data.UploadWaterPosition); //水印位置
  144. Fields.Add("UploadWaterPath", data.UploadWaterPath); //水印图片
  145. Fields.Add("RightInfo", data.RightInfo); //版权信息
  146. Fields.Add("Address", data.Address); //企业地址
  147. Fields.Add("Phone", data.Phone); //联系电话
  148. Fields.Add("WebStatCode", data.WebStatCode); //网站统计代码
  149. Fields.Add("Logo", data.Logo); //Logo图片
  150. Fields.Add("StartAdPhoto", data.StartAdPhoto); //App启动图片
  151. Fields.Add("UploadOss", data.UploadOss);
  152. SystemSet check = bsdb.SystemSet.FirstOrDefault();
  153. if (check == null)
  154. {
  155. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Add("SystemSet", Fields, 0);
  156. }
  157. else
  158. {
  159. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("SystemSet", Fields, data.Id);
  160. }
  161. AddSysLog(data.Id.ToString(), "SystemSet", "update");
  162. bsdb.SaveChanges();
  163. return "success";
  164. }
  165. public IActionResult AppStart()
  166. {
  167. ViewBag.right = _accessor.HttpContext.Request.Query["right"];
  168. return View();
  169. }
  170. [HttpPost]
  171. public string AppStart(SystemSet data)
  172. {
  173. Dictionary<string, object> Fields = new Dictionary<string, object>();
  174. Fields.Add("StartAdPhoto", data.StartAdPhoto); //App启动图片
  175. SystemSet check = bsdb.SystemSet.FirstOrDefault();
  176. if (check == null)
  177. {
  178. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Add("SystemSet", Fields, 0);
  179. }
  180. else
  181. {
  182. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("SystemSet", Fields, data.Id);
  183. }
  184. AddSysLog(data.Id.ToString(), "SystemSet", "AppStart");
  185. FileUpdateInfo fileUpdateInfo = bsdb.FileUpdateInfo.FirstOrDefault(m => m.FileName == data.StartAdPhoto);
  186. if (fileUpdateInfo == null)
  187. {
  188. string Path = data.StartAdPhoto.Substring(0, data.StartAdPhoto.LastIndexOf("/") + 1);
  189. if (Path.Contains("static"))
  190. {
  191. Path = Path.Substring(Path.IndexOf("static"));
  192. }
  193. string FileName = data.StartAdPhoto.Substring(data.StartAdPhoto.LastIndexOf("/") + 1);
  194. bsdb.FileUpdateInfo.Add(new FileUpdateInfo()
  195. {
  196. CreateDate = DateTime.Now,
  197. UpdateDate = DateTime.Now,
  198. FileName = FileName,
  199. Path = Path,
  200. VersionNum = 1,
  201. });
  202. }
  203. bsdb.SaveChanges();
  204. return "success";
  205. }
  206. public JsonResult UploadPhoto([FromForm] IFormCollection rf)
  207. {
  208. IFormFile imgFile = rf.Files[0];
  209. SystemSet set = bsdb.SystemSet.FirstOrDefault() ?? new SystemSet();
  210. string path = MySystemLib.SystemPublicFuction.GetPicPath(imgFile, "skin/app/default/static/images/", function.ReadInstance("/WebRootPath.txt"), "startadphoto" + DateTime.Now.ToString("yyMMddHHmm"));
  211. return Json(new AppResultJson() { Status = "1", Info = "", Data = path.Replace("wwwroot/", "") });
  212. }
  213. #endregion
  214. #region 删除系统设置信息
  215. /// <summary>
  216. /// 删除系统设置信息
  217. /// </summary>
  218. /// <returns></returns>
  219. public string Delete(string Id)
  220. {
  221. string[] idlist = Id.Split(new char[] { ',' });
  222. AddSysLog(Id, "SystemSet", "del");
  223. foreach (string subid in idlist)
  224. {
  225. int id = int.Parse(subid);
  226. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Delete("SystemSet", id);
  227. }
  228. bsdb.SaveChanges();
  229. return "success";
  230. }
  231. #endregion
  232. #region 开启
  233. /// <summary>
  234. /// 开启
  235. /// </summary>
  236. /// <returns></returns>
  237. public string Open(string Id)
  238. {
  239. string[] idlist = Id.Split(new char[] { ',' });
  240. AddSysLog(Id, "SystemSet", "open");
  241. foreach (string subid in idlist)
  242. {
  243. int id = int.Parse(subid);
  244. Dictionary<string, object> Fields = new Dictionary<string, object>();
  245. Fields.Add("Status", 1);
  246. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("SystemSet", Fields, id);
  247. }
  248. bsdb.SaveChanges();
  249. return "success";
  250. }
  251. #endregion
  252. #region 关闭
  253. /// <summary>
  254. /// 关闭
  255. /// </summary>
  256. /// <returns></returns>
  257. public string Close(string Id)
  258. {
  259. string[] idlist = Id.Split(new char[] { ',' });
  260. AddSysLog(Id, "SystemSet", "close");
  261. foreach (string subid in idlist)
  262. {
  263. int id = int.Parse(subid);
  264. Dictionary<string, object> Fields = new Dictionary<string, object>();
  265. Fields.Add("Status", 0);
  266. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Edit("SystemSet", Fields, id);
  267. }
  268. bsdb.SaveChanges();
  269. return "success";
  270. }
  271. #endregion
  272. #region 排序
  273. /// <summary>
  274. /// 排序
  275. /// </summary>
  276. /// <param name="Id"></param>
  277. public string Sort(int Id, int Sort)
  278. {
  279. new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).Sort("SystemSet", Sort, Id);
  280. AddSysLog(Id.ToString(), "SystemSet", "sort");
  281. return "success";
  282. }
  283. #endregion
  284. #region 导入数据
  285. /// <summary>
  286. /// 导入数据
  287. /// </summary>
  288. /// <param name="ExcelData"></param>
  289. public string Import(string ExcelData)
  290. {
  291. ExcelData = HttpUtility.UrlDecode(ExcelData);
  292. JsonData list = JsonMapper.ToObject(ExcelData);
  293. for (int i = 1; i < list.Count; i++)
  294. {
  295. JsonData dr = list[i];
  296. bsdb.SystemSet.Add(new SystemSet()
  297. {
  298. CreateDate = DateTime.Now,
  299. UpdateDate = DateTime.Now,
  300. });
  301. bsdb.SaveChanges();
  302. }
  303. AddSysLog("0", "SystemSet", "Import");
  304. return "success";
  305. }
  306. #endregion
  307. #region 导出Excel
  308. /// <summary>
  309. /// 导出Excel
  310. /// </summary>
  311. /// <returns></returns>
  312. public JsonResult ExportExcel(SystemSet data)
  313. {
  314. Dictionary<string, string> Fields = new Dictionary<string, string>();
  315. Fields.Add("WebUrl", "2"); //网站地址
  316. Fields.Add("WebName", "2"); //网站名称
  317. Dictionary<string, object> obj = new AdminContentOther(_accessor.HttpContext, PublicFunction.BsTables).IndexData("SystemSet", Fields, "Id desc", "False", 1, 20000, "", "", false);
  318. List<Dictionary<string, object>> diclist = obj["data"] as List<Dictionary<string, object>>;
  319. Dictionary<string, object> result = new Dictionary<string, object>();
  320. result.Add("Status", "1");
  321. result.Add("Info", "Excel报表-" + DateTime.Now.ToString("yyyy-MM-ddTHH:mm:ss") + ".xlsx");
  322. result.Add("Obj", diclist);
  323. Dictionary<string, object> ReturnFields = new Dictionary<string, object>();
  324. result.Add("Fields", ReturnFields);
  325. AddSysLog("0", "SystemSet", "ExportExcel");
  326. return Json(result);
  327. }
  328. #endregion
  329. }
  330. }