BaseController.class.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <?php
  2. namespace Api\Controller;
  3. use Think\Controller;
  4. class BaseController extends Controller {
  5. public function checkLogin($redirect = true){
  6. //debug
  7. //$login_user = D("User")->where("username = 'showdoc' ")->find();
  8. //session("login_user" , $login_user);
  9. if ( ! session("login_user")) {
  10. $cookie_token = cookie('cookie_token');
  11. if ($cookie_token) {
  12. $ret = D("UserToken")->getToken($cookie_token);
  13. if ($ret && $ret['token_expire'] > time() ) {
  14. D("UserToken")->setLastTime($cookie_token);
  15. $login_user = D("User")->where("uid = $ret[uid]")->find();
  16. unset($ret['password']);
  17. session("login_user" , $login_user);
  18. return $login_user ;
  19. }
  20. }
  21. if ($redirect) {
  22. $this->sendError(10102);
  23. exit();
  24. }
  25. }else{
  26. return session("login_user") ;
  27. }
  28. }
  29. //检查是否是管理员
  30. public function checkAdmin($redirect = true){
  31. $login_user = session("login_user") ;
  32. if ($login_user) {
  33. if ($login_user['groupid'] == 1 ) {
  34. return true ;
  35. }
  36. }
  37. if ($redirect) {
  38. $this->sendError(10103);
  39. exit();
  40. }
  41. return false;
  42. }
  43. /**
  44. * 返回json结果
  45. */
  46. protected function sendResult($array){
  47. if (isset($array['error_code'])) {
  48. $result['error_code'] = $array['error_code'] ;
  49. $result['error_message'] = $array['error_message'] ;
  50. }
  51. else{
  52. $result['error_code'] = 0 ;
  53. $result['data'] = $array ;
  54. }
  55. //header('Access-Control-Allow-Origin: http://127.0.0.1:8080');//允许跨域请求
  56. //header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Connection, User-Agent, Cookie');
  57. //header('Access-Control-Allow-Credentials : true');//允许跨域请求
  58. echo json_encode($result);
  59. //如果开启API调试模式,则记录请求参数和返回结果
  60. if (C('API_LOG')) {
  61. $info = '';
  62. $info .= "\n\n【★★★★★★★★★★★】";
  63. $info .= "\n请求接口:".MODULE_NAME ."/".CONTROLLER_NAME."/".ACTION_NAME."";
  64. $info .= "\n请求".'$_REQUEST'.":\n";
  65. $info .= json_encode($_REQUEST);
  66. $info .= "\n返回结果:\n";
  67. $info .= json_encode($result)."\n";
  68. $info .= "【★★★★★★★★★★★】\n";
  69. \Think\log::record($info , 'INFO');
  70. }
  71. }
  72. //返回错误提示
  73. protected function sendError($error_code , $error_message = ''){
  74. $error_code = $error_code ? $error_code : 10103 ;
  75. if (!$error_message) {
  76. $error_codes = C("error_codes");
  77. foreach ($error_codes as $key => $value) {
  78. if ($key == $error_code ) {
  79. $error_message = $value ;
  80. }
  81. }
  82. }
  83. $array['error_code'] = $error_code;
  84. $array['error_message'] = $error_message ;
  85. $this->sendResult($array);
  86. }
  87. //判断某用户是否有项目管理权限(项目成员member_group_id为1,以及 项目创建者)
  88. protected function checkItemPermn($uid , $item_id){
  89. if (!$uid) {
  90. return false;
  91. }
  92. if (session("mamage_item_".$item_id)) {
  93. return true;
  94. }
  95. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  96. if ($item['uid'] && $item['uid'] == $uid) {
  97. session("mamage_item_".$item_id , 1 );
  98. return true;
  99. }
  100. $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' and member_group_id = 1 ",array($item_id,$uid))->find();
  101. if ($ItemMember) {
  102. session("mamage_item_".$item_id , 1 );
  103. return true;
  104. }
  105. return false;
  106. }
  107. //判断某用户是否为项目创建者
  108. protected function checkItemCreator($uid , $item_id){
  109. if (!$uid) {
  110. return false;
  111. }
  112. if (session("creat_item_".$item_id)) {
  113. return true;
  114. }
  115. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  116. if ($item['uid'] && $item['uid'] == $uid) {
  117. session("creat_item_".$item_id , 1 );
  118. return true;
  119. }
  120. return false;
  121. }
  122. //判断某用户是否有项目访问权限(公开项目的话所有人可访问,私有项目则项目成员、项目创建者和访问密码输入者可访问)
  123. protected function checkItemVisit($uid , $item_id, $refer_url= ''){
  124. if (session("visit_item_".$item_id)) {
  125. return true;
  126. }
  127. if ($this->checkItemCreator($uid , $item_id)) {
  128. session("visit_item_".$item_id , 1 );
  129. return true;
  130. }
  131. $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' ",array($item_id,$uid))->find();
  132. if ($ItemMember) {
  133. session("visit_item_".$item_id , 1 );
  134. return true;
  135. }
  136. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  137. if ($item['password']) {
  138. return false;
  139. }else{
  140. session("visit_item_".$item_id , 1 );
  141. return true;
  142. }
  143. }
  144. }