WeixinService.php 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  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) {
  29. file_put_contents('record_ip.txt',date("Y-m-d H:i:s",time()).json_encode($data) . PHP_EOL."来源IP".$msg.PHP_EOL,8);
  30. return [false, 'IP未入白名单'];
  31. }
  32. list($status, $msg) = $this->getToken();
  33. if(! $status) return [false, $msg];
  34. $config = config('qingyaoWx');
  35. $url = sprintf($config['get_article'], $msg);
  36. $offset = empty($data['page_index']) ? 1 : $data['page_index'] - 1;
  37. $count = empty($data['page_size']) || $data['page_size'] > 10 ? 10 : $data['page_size'];
  38. $post = [
  39. 'offset' => $offset,
  40. 'count' => $count,
  41. 'no_content' => 1,
  42. ];
  43. $result = $this->curlOpen($url, ['post' => json_encode($post)]);
  44. $result = json_decode($result,true);
  45. if(isset($result['errmsg'])) return [false, $result['errmsg']];
  46. return [true, ['data' => $result['item'] ?? [], 'total' => $result['total_count'], 'data_count' => $result['item_count']]];
  47. }
  48. public function getPublicWxArticleDetail($data){
  49. list($status, $msg) = $this->rule($data);
  50. if(! $status) {
  51. file_put_contents('record_ip.txt',date("Y-m-d H:i:s",time()).json_encode($data) . PHP_EOL."来源IP".$msg.PHP_EOL,8);
  52. return [false, 'IP未入白名单'];
  53. }
  54. if(empty($data['article_id'])) return [false, '文章ID不能为空'];
  55. list($status, $msg) = $this->getToken();
  56. if(! $status) return [false, $msg];
  57. $config = config('qingyaoWx');
  58. $url = sprintf($config['get_article_detail'], $msg);
  59. $post = [
  60. 'article_id' => $data['article_id'],
  61. ];
  62. $result = $this->curlOpen($url, ['post' => json_encode($post)]);
  63. $result = json_decode($result,true);
  64. if(isset($result['errmsg'])) return [false, $result['errmsg']];
  65. return [true, ['data' => $result['news_item'] ?? [] ]];
  66. }
  67. public function getPublicWxMaterial($data){
  68. list($status, $msg) = $this->rule($data);
  69. if(! $status) {
  70. file_put_contents('record_ip.txt',date("Y-m-d H:i:s",time()).json_encode($data) . PHP_EOL."来源IP".$msg.PHP_EOL,8);
  71. return [false, 'IP未入白名单'];
  72. }
  73. list($status, $msg) = $this->getToken();
  74. if(! $status) return [false, $msg];
  75. $config = config('qingyaoWx');
  76. $url = sprintf($config['get_material'], $msg);
  77. $offset = empty($data['page_index']) ? 1 : $data['page_index'] - 1;
  78. $count = empty($data['page_size']) || $data['page_size'] > 10 ? 10 : $data['page_size'];
  79. $post = [
  80. 'offset' => $offset,
  81. 'count' => $count,
  82. 'type' => 'news',
  83. ];
  84. $result = $this->curlOpen($url, ['post' => json_encode($post)]);
  85. $result = json_decode($result,true);
  86. if(isset($result['errmsg'])) return [false, $result['errmsg']];
  87. return [true, ['data' => $result['item'] ?? [], 'total' => $result['total_count'], 'data_count' => $result['item_count']]];
  88. }
  89. public function getPublicWxDraft($data){
  90. list($status, $msg) = $this->rule($data);
  91. if(! $status) {
  92. file_put_contents('record_ip.txt',date("Y-m-d H:i:s",time()).json_encode($data) . PHP_EOL."来源IP".$msg.PHP_EOL,8);
  93. return [false, 'IP未入白名单'];
  94. }
  95. list($status, $msg) = $this->getToken();
  96. if(! $status) return [false, $msg];
  97. $config = config('qingyaoWx');
  98. $url = sprintf($config['get_draft'], $msg);
  99. $offset = empty($data['page_index']) ? 1 : $data['page_index'] - 1;
  100. $count = empty($data['page_size']) || $data['page_size'] > 10 ? 10 : $data['page_size'];
  101. $post = [
  102. 'offset' => $offset,
  103. 'count' => $count,
  104. 'no_content' => 0,
  105. ];
  106. $result = $this->curlOpen($url, ['post' => json_encode($post)]);
  107. $result = json_decode($result,true);
  108. if(isset($result['errmsg'])) return [false, $result['errmsg']];
  109. return [true, ['data' => $result['item'] ?? [], 'total' => $result['total_count'], 'data_count' => $result['item_count']]];
  110. }
  111. public function rule($data){
  112. // 获取用户的IP地址
  113. $userIP = $_SERVER['REMOTE_ADDR'];
  114. // 获取设置的IP地址
  115. $allowedIPs = $this->allowedIPs();
  116. if(empty($allowedIPs)) return [false, $userIP];
  117. // 校验用户IP是否在允许的范围内
  118. $isValidIP = false;
  119. foreach ($allowedIPs as $allowedIP) {
  120. if (strpos($allowedIP, '/') !== false) {
  121. // IP段表示法校验
  122. list($subnet, $mask) = explode('/', $allowedIP);
  123. if ((ip2long($userIP) & ~((1 << (32 - $mask)) - 1)) == ip2long($subnet)) {
  124. $isValidIP = true;
  125. break;
  126. }
  127. } else {
  128. // 单个IP地址校验
  129. if ($allowedIP === $userIP) {
  130. $isValidIP = true;
  131. break;
  132. }
  133. }
  134. }
  135. return [$isValidIP, $userIP];
  136. }
  137. public function allowedIPs(){
  138. $allowedIPs = Settings::where('setting_name','allowedIPs')->first();
  139. if(empty($allowedIPs) || empty($allowedIPs->setting_value)) return [];
  140. return explode(',',$allowedIPs->setting_value);
  141. }
  142. }