base_controller.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  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. if (new.target === BaseController) {
  26. throw new Error('BaseController不能实例化,只能继承使用。');
  27. }
  28. }
  29. /**
  30. * 初始化函数
  31. *
  32. * @param {object} request
  33. * @param {object} response
  34. * @param {function} next
  35. * @return {void}
  36. */
  37. init(request, response, next) {
  38. // 获取当前控制器和动作名称
  39. let urlInfo = Url.parse(request.originalUrl, true);
  40. let url = urlInfo.pathname.substr(1);
  41. let actionInfo = url.split('/');
  42. let controller = 'index';
  43. let action = 'index';
  44. switch (actionInfo.length) {
  45. case 1:
  46. controller = actionInfo[0];
  47. break;
  48. case 2:
  49. controller = actionInfo[0];
  50. action = actionInfo[1];
  51. break;
  52. default:
  53. controller = actionInfo[0];
  54. break;
  55. }
  56. try {
  57. // 校验权限
  58. let currentPermission = request.session.managerData.permission;
  59. currentPermission = currentPermission.split(',');
  60. let withoutPermission = ['login', 'dashboard'];
  61. // 工具页面整合
  62. let toolPermission = ['rationRepository', 'stdBillsmain'];
  63. let hasToolPermission = false;
  64. if (controller === 'tool') {
  65. for (let tmpPermission of toolPermission) {
  66. if (currentPermission.indexOf(tmpPermission) >= 0) {
  67. hasToolPermission = true;
  68. break;
  69. }
  70. }
  71. }
  72. if (!hasToolPermission && withoutPermission.indexOf(controller) < 0 &&
  73. (currentPermission.length <= 0 || currentPermission.indexOf(controller)) < 0) {
  74. console.log(currentPermission);
  75. console.log(controller);
  76. throw '没有权限';
  77. }
  78. // 菜单数据
  79. response.locals.menu = menuData;
  80. // 二级菜单数据
  81. response.locals.secondMenu = menuData[controller] !== undefined && menuData[controller].children !== undefined ?
  82. menuData[controller].children : {};
  83. // url相关数据
  84. response.locals.urlQuery = JSON.stringify(urlInfo.query);
  85. response.locals.controller = controller;
  86. response.locals.action = action;
  87. // 用户session数据
  88. response.locals.manager = request.session.managerData;
  89. // moment工具
  90. response.locals.moment = Moment;
  91. } catch (error) {
  92. console.log(error);
  93. response.redirect('/dashboard');
  94. return;
  95. }
  96. next();
  97. }
  98. /**
  99. * 验证方法
  100. *
  101. * @param {object} request
  102. * @param {object} response
  103. * @param {function} next
  104. * @return {void}
  105. */
  106. auth(request, response, next) {
  107. // 判断session
  108. let mangerData = request.session.managerData;
  109. try {
  110. if (typeof mangerData !== 'object' || Object.keys(mangerData).length < 0) {
  111. throw 'err data';
  112. }
  113. if (mangerData.username === undefined || mangerData.loginTime === undefined) {
  114. throw 'username empty';
  115. }
  116. // 校验session
  117. let sessionToken = crypto.createHmac('sha1', mangerData.loginTime + '')
  118. .update(mangerData.username).digest().toString('base64');
  119. if (sessionToken !== mangerData.sessionToken) {
  120. throw 'session error';
  121. }
  122. } catch (error) {
  123. response.redirect('/login');
  124. return;
  125. }
  126. next();
  127. }
  128. }
  129. export default BaseController;