isForbidden.php 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <?php
  2. namespace App\Http\Middleware;
  3. use Agent;
  4. use App\Components\IP;
  5. use Closure;
  6. use Illuminate\Http\Request;
  7. use Log;
  8. use Response;
  9. class isForbidden
  10. {
  11. /**
  12. * 限制机器人、指定IP访问
  13. *
  14. * @param Request $request
  15. * @param Closure $next
  16. *
  17. * @return mixed
  18. */
  19. public function handle(Request $request, Closure $next)
  20. {
  21. // 拒绝机器人访问
  22. if (sysConfig('is_forbid_robot') && Agent::isRobot()) {
  23. Log::info("识别到机器人访问(".IP::getClientIp().")");
  24. return Response::view('auth.error', ['message' => trans('error.ForbiddenRobot')], 403);
  25. }
  26. // 拒绝通过订阅链接域名访问网站,防止网站被探测
  27. if (false !== strpos(sysConfig('subscribe_domain'), $request->getHost())
  28. && !str_contains(sysConfig('subscribe_domain'), sysConfig('website_url'))) {
  29. Log::info("识别到通过订阅链接访问,强制跳转至百度(".IP::getClientIp().")");
  30. return redirect('https://www.baidu.com');
  31. }
  32. $ip = IP::getClientIP();
  33. $ipLocation = IP::getIPInfo($ip);
  34. // 拒绝无IP请求
  35. if (!$ipLocation || empty(array_filter($ipLocation))) {
  36. return Response::view('auth.error', ['message' => trans('error.ForbiddenAccess')], 403);
  37. }
  38. if (!in_array($ipLocation['country'], ['本机地址', '局域网'])) {
  39. // 拒绝大陆IP访问
  40. if (sysConfig('is_forbid_china') && in_array($ipLocation['country'], ['China', '中国'])
  41. && !in_array($ipLocation['province'], ['香港', '澳门', '台湾', '台湾省'])) {
  42. Log::info('识别到大陆IP,拒绝访问:'.$ip);
  43. return Response::view('auth.error', ['message' => trans('error.ForbiddenChina')], 403);
  44. }
  45. // 拒绝非大陆IP访问
  46. if (sysConfig('is_forbid_oversea') && !in_array($ipLocation['country'], ['China', '中国', 'Taiwan', 'Hong Kong', 'Macao'])) {
  47. Log::info('识别到海外IP,拒绝访问:'.$ip.' - '.$ipLocation['country']);
  48. return Response::view('auth.error', ['message' => trans('error.ForbiddenOversea')], 403);
  49. }
  50. }
  51. return $next($request);
  52. }
  53. }