base_controller.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. /**
  2. * 控制器基类
  3. *
  4. * @author CaiAoLin
  5. * @date 2017/6/29
  6. * @version
  7. */
  8. import crypto from "crypto";
  9. import Url from "url";
  10. import Moment from "moment";
  11. import menuData from "../../../config/menu";
  12. class BaseController {
  13. /**
  14. * 页面title
  15. *
  16. * @var string
  17. */
  18. title = '';
  19. /**
  20. * 构造函数
  21. *
  22. * @return {void}
  23. */
  24. constructor() {
  25. /**
  26. * 使BaseController可以实例化,可作为中间件使用
  27. */
  28. /*if (new.target === BaseController) {
  29. throw new Error('BaseController不能实例化,只能继承使用。');
  30. }*/
  31. }
  32. /**
  33. * 初始化函数
  34. *
  35. * @param {object} request
  36. * @param {object} response
  37. * @param {function} next
  38. * @return {void}
  39. */
  40. init(request, response, next) {
  41. // 获取当前控制器和动作名称
  42. let urlInfo = Url.parse(request.originalUrl, true);
  43. let url = urlInfo.pathname.substr(1);
  44. let actionInfo = url.split('/');
  45. let controller = 'index';
  46. let action = 'index';
  47. switch (actionInfo.length) {
  48. case 1:
  49. controller = actionInfo[0];
  50. break;
  51. case 2:
  52. controller = actionInfo[0];
  53. action = actionInfo[1];
  54. break;
  55. default:
  56. controller = actionInfo[0];
  57. break;
  58. }
  59. try {
  60. // 如果不适超级管理员则判断权限
  61. let sessionManager = request.session.managerData;
  62. if (sessionManager.superAdmin !== 1) {
  63. let currentPermission = sessionManager.permission;
  64. // 校验权限
  65. currentPermission = currentPermission.split(',');
  66. let withoutPermission = ['login', 'dashboard'];
  67. // 工具页面整合
  68. let toolPermission = ['rationRepository', 'stdBillsmain', 'stdGljRepository'];
  69. let hasToolPermission = false;
  70. if (controller === 'tool') {
  71. for (let tmpPermission of toolPermission) {
  72. if (currentPermission.indexOf(tmpPermission) >= 0) {
  73. hasToolPermission = true;
  74. break;
  75. }
  76. }
  77. }
  78. if (!hasToolPermission && withoutPermission.indexOf(controller) < 0 &&
  79. (currentPermission.length <= 0 || currentPermission.indexOf(controller)) < 0) {
  80. throw '没有权限';
  81. }
  82. }
  83. // 菜单数据
  84. response.locals.menu = menuData;
  85. // 二级菜单数据
  86. response.locals.secondMenu = menuData[controller] !== undefined && menuData[controller].children !== undefined ?
  87. menuData[controller].children : {};
  88. // url相关数据
  89. response.locals.urlQuery = JSON.stringify(urlInfo.query);
  90. response.locals.controller = controller;
  91. response.locals.action = action;
  92. // 用户session数据
  93. response.locals.manager = sessionManager;
  94. // moment工具
  95. response.locals.moment = Moment;
  96. } catch (error) {
  97. console.log(error);
  98. response.redirect('/dashboard');
  99. return;
  100. }
  101. next();
  102. }
  103. /**
  104. * 验证方法
  105. *
  106. * @param {object} request
  107. * @param {object} response
  108. * @param {function} next
  109. * @return {void}
  110. */
  111. auth(request, response, next) {
  112. // 判断session
  113. let mangerData = request.session.managerData;
  114. try {
  115. if (typeof mangerData !== 'object' || Object.keys(mangerData).length < 0) {
  116. throw 'err data';
  117. }
  118. if (mangerData.username === undefined || mangerData.loginTime === undefined) {
  119. throw 'username empty';
  120. }
  121. // 校验session
  122. let sessionToken = crypto.createHmac('sha1', mangerData.loginTime + '')
  123. .update(mangerData.username).digest().toString('base64');
  124. if (sessionToken !== mangerData.sessionToken) {
  125. throw 'session error';
  126. }
  127. } catch (error) {
  128. response.redirect('/login');
  129. return;
  130. }
  131. next();
  132. }
  133. }
  134. export default BaseController;