Api.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. namespace app\common\controller;
  3. use app\common\model\User;
  4. use think\exception\HttpResponseException;
  5. use think\facade\Request;
  6. use think\Response;
  7. /**
  8. * API控制器基类
  9. */
  10. class Api
  11. {
  12. /**
  13. * @var Request Request 实例
  14. */
  15. protected $request;
  16. /**
  17. * @var bool 验证失败是否抛出异常
  18. */
  19. protected $failException = true;
  20. /**
  21. * 默认响应输出类型,支持json/xml
  22. * @var string
  23. */
  24. protected $responseType = 'json';
  25. /**
  26. * 操作成功返回的数据
  27. * @param string $msg 提示信息
  28. * @param mixed $data 要返回的数据
  29. * @param int $code 错误码,默认为1
  30. * @param string $type 输出类型
  31. * @param array $header 发送的 Header 信息
  32. */
  33. protected function success($msg = '', $data = null , $is_login = 1, $code = 1, $type = null, array $header = [])
  34. {
  35. $this->result($msg, $data, $is_login, $code, $type, $header);
  36. }
  37. /**
  38. * 操作失败返回的数据
  39. * @param string $msg 提示信息
  40. * @param mixed $data 要返回的数据
  41. * @param int $code 错误码,默认为0
  42. * @param string $type 输出类型
  43. * @param array $header 发送的 Header 信息
  44. */
  45. protected function error($msg = '', $data = null, $is_login = 1, $code = 0, $type = null, array $header = [])
  46. {
  47. $this->result($msg, $data, $is_login, $code, $type, $header);
  48. }
  49. /**
  50. * 返回封装后的 API 数据到客户端
  51. * @access protected
  52. * @param mixed $msg 提示信息
  53. * @param mixed $data 要返回的数据
  54. * @param int $code 错误码,默认为0
  55. * @param string $type 输出类型,支持json/xml/jsonp
  56. * @param array $header 发送的 Header 信息
  57. * @return void
  58. * @throws HttpResponseException
  59. */
  60. protected function result($msg, $data = null, $is_login, $code = 0, $type = null, array $header = [])
  61. {
  62. $result = [
  63. 'code' => $code,
  64. 'is_login' => $is_login,
  65. 'msg' => $msg,
  66. 'time' => Request::instance()->server('REQUEST_TIME'),
  67. 'data' => $data,
  68. ];
  69. // 如果未设置类型则自动判断
  70. $type = $type ? $type : 'json';
  71. if (isset($header['statuscode']))
  72. {
  73. $code = $header['statuscode'];
  74. unset($header['statuscode']);
  75. }
  76. else
  77. {
  78. //未设置状态码,根据code值判断
  79. $code = $code >= 1000 || $code < 200 ? 200 : $code;
  80. }
  81. $response = Response::create($result, $type, $code)->header($header);
  82. throw new HttpResponseException($response);
  83. }
  84. /**
  85. * 判断登录
  86. * @return bool
  87. */
  88. protected function check_login(){
  89. $user = app()->session->get('us');
  90. if (!$user){
  91. $this->error('请先登录','',0);
  92. }
  93. $userinfo = User::where('id',$user['id'])->find();
  94. if ($userinfo['status']!=1){
  95. app()->session->clear();
  96. app()->session->destroy();
  97. $this->error('账号被禁用','',0);
  98. }
  99. return true;
  100. }
  101. }