SensitiveMiddleware.php 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Middleware\Auth;
  4. use App\Tools\PublicData;
  5. use Hyperf\HttpServer\Contract\RequestInterface;
  6. use Hyperf\HttpServer\Contract\ResponseInterface as HttpResponse;
  7. use Psr\Container\ContainerInterface;
  8. use Psr\Http\Message\ResponseInterface;
  9. use Psr\Http\Message\ServerRequestInterface;
  10. use Psr\Http\Server\MiddlewareInterface;
  11. use Psr\Http\Server\RequestHandlerInterface;
  12. use function Hyperf\Support\env;
  13. class SensitiveMiddleware implements MiddlewareInterface
  14. {
  15. protected ContainerInterface $container;
  16. protected RequestInterface $request;
  17. protected HttpResponse $response;
  18. public function __construct( RequestInterface $request, HttpResponse $response)
  19. {
  20. $this->request = $request;
  21. $this->response = $response;
  22. }
  23. public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
  24. {
  25. try {
  26. $req = $this->request->all();
  27. $concatenated = "";
  28. if($req){
  29. foreach ($req as $value) {
  30. if (is_array($value)) {
  31. // 如果值是数组,将数组元素用逗号连接
  32. $concatenated.= implode(',', $value);
  33. } else {
  34. // 如果不是数组,直接拼接
  35. $concatenated.= $value;
  36. }
  37. }
  38. }
  39. if(empty($concatenated)){
  40. return $handler->handle($request);
  41. }else{
  42. $concatenated = preg_replace('/[0-9]/', '', $concatenated);
  43. //白名单
  44. $filterArray = array("http", "https");
  45. $concatenated = str_replace($filterArray, '', $concatenated);
  46. }
  47. $url = env("SENSITIVE_WORD")."?msg=".urlencode($concatenated);
  48. $rep = PublicData::http_get($url);
  49. if (preg_match('/\{[^{}]*"code":[^}]*\}/', $rep, $matches)) {
  50. $jsonString = $matches[0];
  51. // 解析 JSON 字符串为 PHP 数组
  52. $jsonData = json_decode($jsonString, true);
  53. if ($jsonData!== null) {
  54. // 输出解析后的 JSON 数据
  55. print_r($jsonData);
  56. if($jsonData['code']==200){
  57. if(isset($jsonData['num']) && $jsonData['num']>0){
  58. return $this->response->json(
  59. [
  60. 'code' => 0,
  61. 'data' => [],
  62. 'message' => "存在敏感词:".$jsonData['ci'],
  63. ]
  64. );
  65. }
  66. }
  67. } else {
  68. return $this->response->json(
  69. [
  70. 'code' => 0,
  71. 'data' => [],
  72. 'message' => '解析敏感词接口失败',
  73. ]
  74. );
  75. }
  76. }
  77. return $handler->handle($request);
  78. }catch (\Exception $e){
  79. return $this->response->json(
  80. [
  81. 'code' => $e->getCode(),
  82. 'data' => [],
  83. 'message' => '敏感词检测失败:'.$e->getMessage(),
  84. ]
  85. );
  86. }
  87. return false;
  88. }
  89. }