控制器

功能介绍

毫无疑问,控制器层是负责处理客户端请求,转发给响应模型,并将结果返回给客户端。EasySwoole 使用了对象池复用模式,降低对象创建、销毁的开销,注入 requestresponse 对象来完成客户端与服务端之间的交互。

示例

App/HttpController/ 目录下增加文件 User.php

代码

  1. <?php
  2. /**
  3. * @CreateTime: 2020/8/19 12:30 上午
  4. * @Author: huizhang <2788828128@qq.com>
  5. * @Copyright: copyright(2020) Easyswoole all rights reserved
  6. * @Description: 用户控制器
  7. */
  8. namespace App\HttpController;
  9. use EasySwoole\Http\AbstractInterface\Controller;
  10. class User extends Controller
  11. {
  12. /**
  13. * 用户信息
  14. *
  15. * @return string
  16. * CreateTime: 2020/8/19 12:37 上午
  17. */
  18. public function userInfo()
  19. {
  20. // 获取 get 参数
  21. $name = $this->request()->getQueryParam('name');
  22. // 输出到终端
  23. var_dump($name);
  24. // 返回给客户端
  25. $this->response()->write($name . PHP_EOL);
  26. // return 返回的值会让框架在此进行控制器方法调度,将继续执行 User 控制器类的 requestTotal 方法
  27. return '/User/requestTotal';
  28. }
  29. /**
  30. * 接口请求量
  31. *
  32. * CreateTime: 2020/8/19 12:37 上午
  33. */
  34. public function requestTotal()
  35. {
  36. $this->response()->write('请求数+1' . PHP_EOL);
  37. // 还可以 return,但不要两个方法互相调用,会导致死循环
  38. }
  39. /**
  40. * 此控制器抛异常时会执行此方法
  41. *
  42. * @param \Throwable $throwable
  43. * @throws \Throwable
  44. * CreateTime: 2020/8/19 12:48 上午
  45. */
  46. public function onException(\Throwable $throwable): void
  47. {
  48. parent::onException($throwable); // TODO: Change the autogenerated stub
  49. }
  50. /**
  51. * gc 方法将在执行完 afterAction 方法之后自动调用,可自行覆盖实现其他的 gc 回收逻辑
  52. *
  53. * CreateTime: 2020/8/19 12:52 上午
  54. */
  55. public function gc()
  56. {
  57. parent::gc(); // TODO: Change the autogenerated stub
  58. }
  59. /**
  60. * 当控制器方法执行结束之后将调用该方法,可自行覆盖该方法实现数据回收等逻辑
  61. *
  62. * @param string|null $actionName
  63. * CreateTime: 2020/8/19 12:51 上午
  64. */
  65. public function afterAction(?string $actionName): void
  66. {
  67. parent::afterAction($actionName); // TODO: Change the autogenerated stub
  68. }
  69. /**
  70. * 当请求方法未找到时,自动调用该方法,可自行覆盖该方法实现自己的逻辑
  71. *
  72. * @param string|null $action
  73. * CreateTime: 2020/8/19 12:51 上午
  74. */
  75. public function actionNotFound(?string $action)
  76. {
  77. parent::actionNotFound($action); // TODO: Change the autogenerated stub
  78. }
  79. /**
  80. * 所有控制器请求都会先经过该方法,如果此方法返回 false 则请求不继续往下执行,可用于权限验证
  81. *
  82. * @param string|null $action
  83. * @return bool|null
  84. * CreateTime: 2020/8/19 12:52 上午
  85. */
  86. public function onRequest(?string $action): ?bool
  87. {
  88. return parent::onRequest($action); // TODO: Change the autogenerated stub
  89. }
  90. }

执行过程

启动 easyswoole

  1. php easyswoole server start

访问

  1. curl http://localhost:9501/user/userInfo?name=easyswoole

执行结果

服务端输出

  1. doc-new git:(master) php easyswoole server start
  2. #!/usr/bin/env php
  3. ______ _____ _
  4. | ____| / ____| | |
  5. | |__ __ _ ___ _ _ | (___ __ __ ___ ___ | | ___
  6. | __| / _` | / __| | | | | \___ \ \ \ /\ / / / _ \ / _ \ | | / _ \
  7. | |____ | (_| | \__ \ | |_| | ____) | \ V V / | (_) | | (_) | | | | __/
  8. |______| \__,_| |___/ \__, | |_____/ \_/\_/ \___/ \___/ |_| \___|
  9. __/ |
  10. |___/
  11. main server SWOOLE_WEB
  12. listen address 0.0.0.0
  13. listen port 9501
  14. worker_num 8
  15. reload_async true
  16. max_wait_time 3
  17. document_root /Users/guoyuzhao/sites/doc-new/Static
  18. enable_static_handler true
  19. pid_file /Users/guoyuzhao/sites/doc-new/Temp/pid.pid
  20. log_file /Users/guoyuzhao/sites/doc-new/Log/swoole.log
  21. user guoyuzhao
  22. swoole version 4.5.2
  23. php version 7.4.8
  24. easyswoole version 3.4.0-dev
  25. run mode dev
  26. temp dir /Users/guoyuzhao/sites/doc-new/Temp
  27. log dir /Users/guoyuzhao/sites/doc-new/Log
  28. string(10) "easyswoole"

客户端输出

  1. ssh curl http://localhost:9501/user/userInfo\?name\=easyswoole
  2. easyswoole
  3. 请求数+1

控制器方法

easyswoole 在控制器基类中实现了几个通用方法,当然用户也可根据需要进行方法重写实现自己的逻辑

onRequest

所有控制器请求都会先经过该方法,如果此方法返回 false 则请求不继续往下执行,可用于权限验证

  1. protected function onRequest(?string $action): ?bool
  2. {
  3. return true;
  4. }

onException

当执行控制器方法抛异常时会调用该方法,可自行覆盖该方法实现异常捕获等逻辑

  1. protected function onException(\Throwable $throwable): void
  2. {
  3. throw $throwable;
  4. }

afterAction

action 执行结束后调用该方法,可自行覆盖该方法实现数据回收等逻辑

  1. protected function afterAction(?string $actionName): void
  2. {
  3. }

actionNotFound

当请求方法未找到时,自动调用此方法

  1. protected function actionNotFound(?string $action)
  2. {
  3. $class = static::class;
  4. $this->writeJson(\EasySwoole\Http\Message\Status::CODE_NOT_FOUND,null,"{$class} has not action for {$action}");
  5. }

gc

gc 方法在 afterAction 方法执行完后调用

  1. protected function gc()
  2. {
  3. //恢复默认值
  4. foreach ($this->defaultProperties as $property => $value) {
  5. $this->{$property} = $value;
  6. }
  7. }

注意事项

  • 只有第一次请求时才会调用构造函数
  • 对象池模式只重置非静态 public 属性
  • 对象池复用模式只针对单一进程,多个 worker 进程不共享
  • 文件夹、文件、类名为大驼峰,变量与类方法小驼峰(规范)
  • action 返回的字符串将会被 url 解析规则以及 route 路由规则解析
  • 两个 action 的 return 不能互相调用,否则将导致死循环