IndexController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Controller;
  4. use App\Tools\CommonService;
  5. use App\Tools\PublicData;
  6. use Hyperf\Di\Annotation\Inject;
  7. use Hyperf\HttpServer\Contract\RequestInterface;
  8. use Hyperf\Validation\Contract\ValidatorFactoryInterface;
  9. use App\Request\FooRequest;
  10. use App\Request\SceneRequest;
  11. use App\Tools\Result;
  12. use Phper666\JWTAuth\JWT;
  13. use ZipArchive;
  14. class IndexController extends AbstractController
  15. {
  16. #[Inject]
  17. protected ValidatorFactoryInterface $validationFactory;
  18. public function index(RequestInterface $request){
  19. $validator = $this->validationFactory->make(
  20. $request->all(),
  21. [
  22. 'foo' => 'required',
  23. 'bar' => 'required',
  24. ],
  25. [
  26. 'foo.required' => 'foo必填',
  27. 'bar.required' => 'bar必填',
  28. ]
  29. );
  30. if ($validator->fails()){
  31. // Handle exception
  32. $errorMessage = $validator->errors()->first();
  33. var_dump($errorMessage);
  34. }
  35. // master123
  36. }
  37. public function verifyCode()
  38. {
  39. $comm = new CommonService();
  40. $ip = $comm->userIp();
  41. $redis = $this->container->get(\Hyperf\Redis\Redis::class);
  42. $config = new \EasySwoole\VerifyCode\Config();
  43. $code = new \EasySwoole\VerifyCode\VerifyCode($config);
  44. $img_code = '';
  45. $characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
  46. $charLength = strlen($characters);
  47. for ($i = 0; $i < 4; $i++) {
  48. $img_code .= $characters[rand(0, $charLength - 1)];
  49. }
  50. //重写验证码
  51. $result = $code->DrawCode((string)$img_code);
  52. $img_code = $result->getImageCode();
  53. $code_uniqid = uniqid("code");
  54. //写入缓存 用于其他方法验证 并且设置过期时间
  55. $redis->set($code_uniqid,$img_code,60000);
  56. return $result?Result::success(['code'=>$code_uniqid,'img'=>$result->getImageBase64()]):Result::error('失败');
  57. // return $result->getImageBase64();
  58. }
  59. // test
  60. /**
  61. * 获取验证码
  62. */
  63. public function getverifyCode(){
  64. $comm = new CommonService();
  65. $ip = $comm->userIp();
  66. $redis = $this->container->get(\Hyperf\Redis\Redis::class);
  67. $img_code = $redis->get('code'.$ip);
  68. return Result::success($img_code);
  69. }
  70. /**
  71. * 检测token是否有效
  72. * @param JWT $jwt
  73. * @return void
  74. */
  75. public function checkVerifyToken(Jwt $jwt,RequestInterface $request)
  76. {
  77. $headerInfo = $request->all();
  78. var_dump($headerInfo);
  79. // $jwt->verifyToken($header['token'][0]);
  80. }
  81. }