WeixinService.php 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace App\Service\Weixin;
  3. use App\Model\Settings;
  4. use App\Service\Service;
  5. use Illuminate\Support\Facades\Redis;
  6. class WeixinService extends Service
  7. {
  8. public function getToken(){
  9. $config = config('qingyaoWx');
  10. $token_key = $config['redis_key'];
  11. $token = Redis::get($token_key);
  12. if(empty($token)){
  13. $url = sprintf($config['get_token'], $config['appid'], $config['appsecret']);
  14. $res = $this->curlOpen($url);
  15. $res = json_decode($res,true);
  16. if(isset($res['errmsg'])) return [false, $res['errmsg']];
  17. if(! isset($res['access_token'])) return [false, 'request error'];
  18. $token = $res['access_token'];
  19. $expire_time = $res['expires_in']-300;
  20. Redis::set($token_key,$token);
  21. Redis::expire($token_key, $expire_time);
  22. return [true,$token];
  23. }
  24. return [true, $token];
  25. }
  26. public function getPublicWxArticle($data){
  27. list($status, $msg) = $this->rule($data);
  28. if(! $status) return [false, 'IP未入白名单'];
  29. list($status, $msg) = $this->getToken();
  30. if(! $status) return [false, $msg];
  31. $config = config('qingyaoWx');
  32. $url = sprintf($config['get_article'], $msg);
  33. $offset = empty($data['page_index']) ? 1 : $data['page_index'] - 1;
  34. $count = empty($data['count']) || $data['count'] > 10 ? 10 : $data['count'];
  35. $post = [
  36. 'offset' => $offset,
  37. 'count' => $count,
  38. 'no_content' => 0,
  39. ];
  40. $result = $this->curlOpen($url, ['post' => json_encode($post)]);
  41. $result = json_decode($result,true);
  42. if(isset($result['errmsg'])) return [false, $result['errmsg']];
  43. return [true, ['data' => $result['item'] ?? [], 'total' => $result['total_count']]];
  44. }
  45. public function rule($data){
  46. // 获取用户的IP地址
  47. $userIP = $_SERVER['REMOTE_ADDR'];
  48. // 获取设置的IP地址
  49. $allowedIPs = $this->allowedIPs();
  50. if(empty($allowedIPs)) return [false, $userIP];
  51. // 校验用户IP是否在允许的范围内
  52. $isValidIP = false;
  53. foreach ($allowedIPs as $allowedIP) {
  54. if (strpos($allowedIP, '/') !== false) {
  55. // IP段表示法校验
  56. list($subnet, $mask) = explode('/', $allowedIP);
  57. if ((ip2long($userIP) & ~((1 << (32 - $mask)) - 1)) == ip2long($subnet)) {
  58. $isValidIP = true;
  59. break;
  60. }
  61. } else {
  62. // 单个IP地址校验
  63. if ($allowedIP === $userIP) {
  64. $isValidIP = true;
  65. break;
  66. }
  67. }
  68. }
  69. return [$isValidIP, $userIP];
  70. }
  71. public function allowedIPs(){
  72. $allowedIPs = Settings::where('setting_name','allowedIPs')->first();
  73. if(empty($allowedIPs) || empty($allowedIPs->setting_value)) return [];
  74. return explode(',',$allowedIPs->setting_value);
  75. }
  76. }