BaseController.class.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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. * 返回json结果
  31. */
  32. protected function sendResult($array){
  33. if (isset($array['error_code'])) {
  34. $result['error_code'] = $array['error_code'] ;
  35. $result['error_message'] = $array['error_message'] ;
  36. }
  37. else{
  38. $result['error_code'] = 0 ;
  39. $result['data'] = $array ;
  40. }
  41. //header('Access-Control-Allow-Origin: http://127.0.0.1:8080');//允许跨域请求
  42. //header('Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept, Connection, User-Agent, Cookie');
  43. //header('Access-Control-Allow-Credentials : true');//允许跨域请求
  44. echo json_encode($result);
  45. //如果开启API调试模式,则记录请求参数和返回结果
  46. if (C('API_LOG')) {
  47. $info = '';
  48. $info .= "\n\n【★★★★★★★★★★★】";
  49. $info .= "\n请求接口:".MODULE_NAME ."/".CONTROLLER_NAME."/".ACTION_NAME."";
  50. $info .= "\n请求".'$_REQUEST'.":\n";
  51. $info .= json_encode($_REQUEST);
  52. $info .= "\n返回结果:\n";
  53. $info .= json_encode($result)."\n";
  54. $info .= "【★★★★★★★★★★★】\n";
  55. \Think\log::record($info , 'INFO');
  56. }
  57. }
  58. //返回错误提示
  59. protected function sendError($error_code , $error_message = ''){
  60. $error_code = $error_code ? $error_code : 10103 ;
  61. if (!$error_message) {
  62. $error_codes = C("error_codes");
  63. foreach ($error_codes as $key => $value) {
  64. if ($key == $error_code ) {
  65. $error_message = $value ;
  66. }
  67. }
  68. }
  69. $array['error_code'] = $error_code;
  70. $array['error_message'] = $error_message ;
  71. $this->sendResult($array);
  72. }
  73. //判断某用户是否有项目管理权限(项目成员member_group_id为1,以及 项目创建者)
  74. protected function checkItemPermn($uid , $item_id){
  75. if (!$uid) {
  76. return false;
  77. }
  78. if (session("mamage_item_".$item_id)) {
  79. return true;
  80. }
  81. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  82. if ($item['uid'] && $item['uid'] == $uid) {
  83. session("mamage_item_".$item_id , 1 );
  84. return true;
  85. }
  86. $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' and member_group_id = 1 ",array($item_id,$uid))->find();
  87. if ($ItemMember) {
  88. session("mamage_item_".$item_id , 1 );
  89. return true;
  90. }
  91. return false;
  92. }
  93. //判断某用户是否为项目创建者
  94. protected function checkItemCreator($uid , $item_id){
  95. if (!$uid) {
  96. return false;
  97. }
  98. if (session("creat_item_".$item_id)) {
  99. return true;
  100. }
  101. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  102. if ($item['uid'] && $item['uid'] == $uid) {
  103. session("creat_item_".$item_id , 1 );
  104. return true;
  105. }
  106. return false;
  107. }
  108. //判断某用户是否有项目访问权限(公开项目的话所有人可访问,私有项目则项目成员、项目创建者和访问密码输入者可访问)
  109. protected function checkItemVisit($uid , $item_id, $refer_url= ''){
  110. if (session("visit_item_".$item_id)) {
  111. return true;
  112. }
  113. if ($this->checkItemCreator($uid , $item_id)) {
  114. session("visit_item_".$item_id , 1 );
  115. return true;
  116. }
  117. $ItemMember = D("ItemMember")->where("item_id = '%d' and uid = '%d' ",array($item_id,$uid))->find();
  118. if ($ItemMember) {
  119. session("visit_item_".$item_id , 1 );
  120. return true;
  121. }
  122. $item = D("Item")->where("item_id = '%d' ",array($item_id))->find();
  123. if ($item['password']) {
  124. return false;
  125. }else{
  126. session("visit_item_".$item_id , 1 );
  127. return true;
  128. }
  129. }
  130. }