承接 zatxm/yrequest 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

zatxm/yrequest

最新稳定版本:2.0.0

Composer 安装命令:

composer require zatxm/yrequest

包简介

PHP's curl simply encapsulates requests and supports requests libraries similar to python to support session context

README 文档

README

yrequest是php的curl简单封装请求,支持类似python的requests库支持session上下文关联请求,重定向也支持此功能,支持并发请求,支持原生模拟浏览器TLS/JA3指纹的验证

使用说明

  • 安装

    composer require zatxm/yrequest (2.0+版本要求php>=8.0)

  • 支持原生模拟浏览器TLS/JA3指纹的验证
    要开启此功能,前往curl-impersonate下载安装,最简单的就是下载编译号的二进制包直接放到可以直接运行的目录如/usr/local/bin
    $option['cmdopt'] = '/usr/local/bin/curl_edge101'; //此值为curl-impersonate执行脚本位置,根据实际情况调整
    此功能会直接返回响应头部和cookie
    测试发现此功能不支持响应流式持续返回数据,会一次性返回数据

  • 简单的通信请求

      <?php
      use Zatxm\YRequest\Curl;
    
      $curl = Curl::boot();
      $url = 'http://xxxx';
      $params = ['a'=>'aaa', 'b'=>'bbb'];
      $headers = ['a'=>'aaa', 'b'=>'bbb'];
      $cookies = ['a'=>'aaa', 'b'=>'bbb'];
      // option目前支持选项如下:
      // async=1异步
      // nobody=1不返回响应内容,cmdopt不支持此配置
      // resheader=1返回响应头部,cmdopt一直返回
      // rescookie=1返回响应cookie,cmdopt一直返回
      // timeout=60设置通信超时时间秒数,默认30
      // followlocation=1是否重定向,cmdopt不支持此配置
      // cmdopt=curl_edge101支持原生模拟浏览器TLS/JA3指纹的验证
      // source=[]原生curl_multi_setopt配置,可能会被上面设置覆盖
      $option = ['nobody'=>1, 'resheader'=>1];
      $res = $curl->url($url)
          ->method('POST')
          ->params($params)
          ->header($headers)
          ->cookie($cookies)
          ->option($option)
          ->go();
      if (CurlErr::is($res)) {
          print_r($res);
          exit;
      }
      print_r($res);
  • 支持同个session的通信请求

      <?php
      use Zatxm\YRequest\CurlOfSession;
    
      $curl = CurlOfSession::boot();
      $url1 = 'http://xxxx';
      $params = ['a'=>'aaa', 'b'=>'bbb'];
      $headers = ['a'=>'aaa', 'b'=>'bbb'];
      $cookies = ['a'=>'aaa', 'b'=>'bbb'];
      $option = ['nobody'=>1, 'resheader'=>1];
      $res = $curl->url($url)
          ->method('POST')
          ->params($params)
          ->header($headers)
          ->cookie($cookies)
          ->option($option)
          ->go();
      if (CurlErr::is($res)) {
          print_r($res);
          exit;
      }
      print_r($res);
      $url2 = 'http://xxxx';
      $params = ['a'=>'aaa', 'b'=>'bbb'];
      $headers = ['a'=>'aaa', 'b'=>'bbb'];
      $cookies = ['a'=>'aaa', 'b'=>'bbb'];
      $option = ['nobody'=>1, 'resheader'=>1];
      $res = $curl->url($url)
          ->method('POST')
          ->params($params)
          ->header($headers)
          ->cookie($cookies)
          ->option($option)
          ->go();
      if (CurlErr::is($res)) {
          print_r($res);
          exit;
      }
      print_r($res);
  • 支持并发通信请求

每个各种multiOtion请求参数和单个Curl请求参数大致相同

  <?php
  use Zatxm\YRequest\Murl;

  $multiOtion = [
      [
          'url' => 'https://xx.xx.xx',
          'params' => ['a'=>'aaa', 'b'=>'bbb'],
          'header' => ['a'=>'aaa', 'b'=>'bbb'],
          'cookie' => ['a'=>'aaa', 'b'=>'bbb'],
          'option' => ['nobody'=>1, 'resheader'=>1]
      ],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx'],
      ['url' => 'https://xx.xx.xx']
  ];
  $murl = Murl::boot();
  $res = $murl->multiOtion($multiOtion)->go();
  print_r($res);

统计信息

  • 总下载量: 292
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 2
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-12-02

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固