HomeController.cs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Data;
  5. using Microsoft.AspNetCore.Mvc;
  6. using Microsoft.AspNetCore.Http;
  7. using MySystem.Models;
  8. using Library;
  9. using LitJson;
  10. namespace MySystem.Areas.Admin.Controllers
  11. {
  12. [Area("Admin")]
  13. [Route("Admin/[controller]/[action]")]
  14. public class HomeController : Controller
  15. {
  16. public BsModels.WebCMSEntities db = new BsModels.WebCMSEntities();
  17. public WebCMSEntities maindb = new WebCMSEntities();
  18. public IHttpContextAccessor _accessor;
  19. public HomeController(IHttpContextAccessor accessor)
  20. {
  21. _accessor = accessor;
  22. }
  23. /// <summary>
  24. /// 主界面
  25. /// </summary>
  26. /// <returns></returns>
  27. public IActionResult Index()
  28. {
  29. if (function.GetSession(_accessor.HttpContext, "IsLogin") != "1")
  30. {
  31. return Redirect("/Admin/Home/Login");
  32. }
  33. ViewBag.SysUserName = function.GetCookie(_accessor.HttpContext, "SysUserName");
  34. List<BsModels.RightDic> RightList = db.RightDic.OrderBy(m => m.Id).ToList();
  35. ViewBag.RightList = RightList;
  36. ViewBag.SysRealName = function.GetCookie(_accessor.HttpContext, "SysRealName");
  37. ViewBag.RightInfo = "," + function.GetSession(_accessor.HttpContext, "RightInfo") + ",";
  38. ViewBag.MyTaskCount = "0";
  39. List<BsModels.RightDic> menus = db.RightDic.Where(m => !string.IsNullOrEmpty(m.Url)).ToList();
  40. ViewBag.menus = menus;
  41. string Role = function.GetCookie(_accessor.HttpContext, "SysRealRole");
  42. ViewBag.Role = Role;
  43. return View();
  44. }
  45. /// <summary>
  46. /// 统计界面
  47. /// </summary>
  48. /// <returns></returns>
  49. public IActionResult Main()
  50. {
  51. BsModels.SystemSet set = db.SystemSet.FirstOrDefault() ?? new BsModels.SystemSet();
  52. ViewBag.SMSCount = set.QueryCount.ToString();
  53. ViewBag.RightInfo = function.GetSession(_accessor.HttpContext, "RightInfo");
  54. List<BsModels.RightDic> menus = db.RightDic.Where(m => m.MainMenu == 1).OrderByDescending(m => m.Sort).ThenBy(m => m.Id).Take(8).ToList();
  55. ViewBag.menus = menus;
  56. List<Dictionary<string, object>> statlist = new List<Dictionary<string, object>>();
  57. List<BsModels.RightDic> stats = db.RightDic.Where(m => m.MainStat == 1).OrderBy(m => m.Id).ToList();
  58. foreach (BsModels.RightDic sub in stats)
  59. {
  60. string url = sub.Url;
  61. if (!string.IsNullOrEmpty(url))
  62. {
  63. string table = url.Split('/')[2];
  64. Dictionary<string, object> item = new Dictionary<string, object>();
  65. item.Add("Name", function.CheckNull(sub.Name).Replace("管理", "").Replace("列表", ""));
  66. int count = 0;
  67. DataTable dt = dbconn.dtable("select count(Id) from " + table);
  68. if (dt.Rows.Count > 0)
  69. {
  70. count = int.Parse(dt.Rows[0][0].ToString());
  71. }
  72. item.Add("Count", count);
  73. statlist.Add(item);
  74. }
  75. }
  76. //统计机具券剩余数量
  77. Dictionary<string, object> otherItem = new Dictionary<string, object>();
  78. otherItem.Add("Name", "电签券库存");
  79. otherItem.Add("Count", maindb.PosCoupons.Count(m => m.IsUse == 0 && m.IsLock == 0 && m.UserId == 0 && m.QueryCount == 1));
  80. statlist.Add(otherItem);
  81. otherItem = new Dictionary<string, object>();
  82. otherItem.Add("Name", "大机券库存");
  83. otherItem.Add("Count", maindb.PosCoupons.Count(m => m.IsUse == 0 && m.IsLock == 0 && m.UserId == 0 && m.QueryCount == 2));
  84. statlist.Add(otherItem);
  85. ViewBag.statlist = statlist;
  86. List<BsModels.RightDic> datalist = db.RightDic.Where(m => m.MainDataList == 1).OrderBy(m => m.Id).ToList();
  87. ViewBag.datalist = datalist;
  88. string Role = function.GetCookie(_accessor.HttpContext, "SysRealRole");
  89. ViewBag.Role = Role;
  90. return View();
  91. }
  92. /// <summary>
  93. /// 搜索菜单
  94. /// </summary>
  95. /// <returns></returns>
  96. public IActionResult Search(string keywords = "")
  97. {
  98. ViewBag.RightInfo = "," + function.GetSession(_accessor.HttpContext, "RightInfo") + ",";
  99. List<BsModels.RightDic> menus = db.RightDic.Where(m => m.Name.Contains(keywords) && !string.IsNullOrEmpty(m.Url)).ToList();
  100. ViewBag.menus = menus;
  101. return View();
  102. }
  103. #region 后台管理员登录
  104. public IActionResult Login()
  105. {
  106. function.WriteSession(_accessor.HttpContext, "GotoLogin", "");
  107. string Pwd = function.MD5_32("ym87540628");
  108. BsModels.SysAdmin sys = db.SysAdmin.FirstOrDefault(m => m.AdminName == "admin");
  109. if (sys == null)
  110. {
  111. string Role = "0";
  112. List<BsModels.SysAdminRole> roles = db.SysAdminRole.ToList();
  113. if (roles.Count > 0)
  114. {
  115. Role = roles[0].Id.ToString();
  116. }
  117. db.SysAdmin.Add(new BsModels.SysAdmin()
  118. {
  119. AdminName = "admin", //用户名
  120. Password = Pwd, //密码
  121. RealName = "系统管理员", //名称
  122. Role = Role,
  123. });
  124. db.SaveChanges();
  125. }
  126. return View();
  127. }
  128. /// <summary>
  129. /// 后台管理员登录
  130. /// </summary>
  131. /// <param name="UserName">用户名</param>
  132. /// <param name="Pwd">密码</param>
  133. /// <returns></returns>
  134. [HttpPost]
  135. public string Login(string UserName, string Pwd, string CheckCode)
  136. {
  137. string result = "";
  138. if (function.GetCookie(_accessor.HttpContext, "checkcode") != CheckCode)
  139. {
  140. result = "验证码错误!!";
  141. }
  142. else
  143. {
  144. Pwd = function.MD5_32(Pwd);
  145. var user = db.SysAdmin.FirstOrDefault(m => m.AdminName == UserName && m.Password == Pwd);
  146. if (user != null)
  147. {
  148. user.LastLoginDate = DateTime.Now;
  149. db.SaveChanges();
  150. function.WriteCookie(_accessor.HttpContext, "SysUserName", user.AdminName);
  151. function.WriteCookie(_accessor.HttpContext, "SysRealName", user.RealName);
  152. function.WriteCookie(_accessor.HttpContext, "SysRealRole", user.Role);
  153. int RoleId = int.Parse(function.CheckInt(user.Role));
  154. BsModels.SysAdminRole Role = db.SysAdminRole.FirstOrDefault(m => m.Id == RoleId) ?? new BsModels.SysAdminRole();
  155. string RightInfo = function.CheckNull(Role.RightInfo);
  156. function.WriteSession(_accessor.HttpContext, "RightInfo", RightInfo);
  157. string UserId = user.Id.ToString();
  158. function.WriteCookie(_accessor.HttpContext, "SysId", UserId);
  159. function.WriteSession(_accessor.HttpContext, "IsLogin", "1");
  160. result = "success";
  161. }
  162. else
  163. {
  164. result = "用户名或密码错误";
  165. }
  166. }
  167. // string result = "";
  168. // Pwd = function.MD5_32(Pwd);
  169. // var user = db.SysAdmin.FirstOrDefault(m => m.AdminName == UserName && m.Password == Pwd);
  170. // if (user != null)
  171. // {
  172. // user.LastLoginDate = DateTime.Now;
  173. // db.SaveChanges();
  174. // function.WriteCookie(_accessor.HttpContext, "SysUserName", user.AdminName);
  175. // function.WriteCookie(_accessor.HttpContext, "SysRealName", user.RealName);
  176. // function.WriteCookie(_accessor.HttpContext, "SysRealRole", user.Role);
  177. // int RoleId = int.Parse(function.CheckInt(user.Role));
  178. // BsModels.SysAdminRole Role = db.SysAdminRole.FirstOrDefault(m => m.Id == RoleId) ?? new BsModels.SysAdminRole();
  179. // string RightInfo = function.CheckNull(Role.RightInfo);
  180. // function.WriteSession(_accessor.HttpContext, "RightInfo", RightInfo);
  181. // string UserId = user.Id.ToString();
  182. // function.WriteCookie(_accessor.HttpContext, "SysId", UserId);
  183. // function.WriteSession(_accessor.HttpContext, "IsLogin", "1");
  184. // result = "success";
  185. // }
  186. // else
  187. // {
  188. // result = "用户名或密码错误";
  189. // }
  190. return result;
  191. }
  192. #endregion
  193. #region 退出登录
  194. /// <summary>
  195. /// 退出登录
  196. /// </summary>
  197. public void Quit()
  198. {
  199. function.WriteCookie(_accessor.HttpContext, "SysUserName", "", -1);
  200. function.WriteCookie(_accessor.HttpContext, "SysRealName", "", -1);
  201. function.WriteCookie(_accessor.HttpContext, "SysId", "", -1);
  202. function.WriteCookie(_accessor.HttpContext, "Role", "", -1);
  203. function.WriteCookie(_accessor.HttpContext, "IsLogin", "", -1);
  204. _accessor.HttpContext.Response.Redirect("/Admin/Home/Login");
  205. }
  206. #endregion
  207. #region 修改登录密码
  208. /// <summary>
  209. /// 修改登录密码
  210. /// </summary>
  211. /// <returns></returns>
  212. public IActionResult LoginPassword()
  213. {
  214. if (function.GetCookie(_accessor.HttpContext, "SysRealRole") == "3")
  215. {
  216. return Redirect("/Admin/Merchants/LoginPassword");
  217. }
  218. return View();
  219. }
  220. public string LoginPasswordPost(string OldPassword, string NewPassword, string NewPassword2)
  221. {
  222. if (string.IsNullOrEmpty(OldPassword))
  223. {
  224. return "请输入旧密码";
  225. }
  226. if (string.IsNullOrEmpty(NewPassword))
  227. {
  228. return "请输入新密码";
  229. }
  230. if (string.IsNullOrEmpty(NewPassword2))
  231. {
  232. return "请确认密码";
  233. }
  234. if (NewPassword != NewPassword2)
  235. {
  236. return "两次密码输入不一致";
  237. }
  238. int SysId = int.Parse(function.CheckInt(function.GetCookie(_accessor.HttpContext, "SysId")));
  239. BsModels.SysAdmin sys = db.SysAdmin.FirstOrDefault(m => m.Id == SysId);
  240. if (sys != null)
  241. {
  242. if (function.MD5_32(OldPassword) != sys.Password)
  243. {
  244. return "旧密码不正确";
  245. }
  246. sys.Password = function.MD5_32(NewPassword);
  247. db.SaveChanges();
  248. return "success";
  249. }
  250. return "修改失败";
  251. }
  252. #endregion
  253. #region 个人资料
  254. /// <summary>
  255. /// 个人资料
  256. /// </summary>
  257. /// <returns></returns>
  258. public IActionResult AdminInfo()
  259. {
  260. if (function.GetCookie(_accessor.HttpContext, "SysRealRole") == "3")
  261. {
  262. return Redirect("/Admin/Merchants/AdminInfo");
  263. }
  264. int SysId = int.Parse(function.CheckInt(function.GetCookie(_accessor.HttpContext, "SysId")));
  265. BsModels.SysAdmin data = db.SysAdmin.FirstOrDefault(m => m.Id == SysId) ?? new BsModels.SysAdmin();
  266. ViewBag.data = data;
  267. return View();
  268. }
  269. public string AdminInfoPost(SysAdmin data)
  270. {
  271. int SysId = int.Parse(function.CheckInt(function.GetCookie(_accessor.HttpContext, "SysId")));
  272. BsModels.SysAdmin sys = db.SysAdmin.FirstOrDefault(m => m.Id == SysId);
  273. if (sys != null)
  274. {
  275. sys.RealName = data.RealName;
  276. db.SaveChanges();
  277. return "success";
  278. }
  279. return "修改失败";
  280. }
  281. #endregion
  282. public string MakeData()
  283. {
  284. OtherMySqlConn.connstr = ConfigurationManager.AppSettings["SqlConnStr"].ToString();
  285. Dictionary<string, Dictionary<string, string>> tables = PublicFunction.MainTables;
  286. foreach (string table in tables.Keys)
  287. {
  288. int num = function.get_Random(50, 100);
  289. for (int i = 0; i < num; i++)
  290. {
  291. string fields = "";
  292. string values = "";
  293. Dictionary<string, string> columns = tables[table];
  294. foreach (string column in columns.Keys)
  295. {
  296. string columnType = columns[column];
  297. fields += column + ",";
  298. if (columnType == "numeric" || columnType == "int")
  299. {
  300. values += function.get_Random(1) + ",";
  301. }
  302. else if (columnType == "datetime")
  303. {
  304. values += "'" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + "',";
  305. }
  306. else if (columnType == "bit")
  307. {
  308. values += "1,";
  309. }
  310. else
  311. {
  312. values += "'" + function.get_Random(20) + "',";
  313. }
  314. }
  315. string sql = "insert into " + table + " (" + fields.TrimEnd(',') + ") values (" + values.TrimEnd(',') + ")";
  316. OtherMySqlConn.op(sql);
  317. }
  318. }
  319. OtherMySqlConn.connstr = "";
  320. return "ok";
  321. }
  322. }
  323. }