moyefu 发表于 2023-12-14 15:25

PHP阿里云签到脚本

本帖最后由 moyefu 于 2023-12-15 09:38 编辑

声明:本文的代码都是仿照大佬门的脚本 播此内容是基于学术研究和学习目的。
最近看到很多小伙伴要一个php的签到脚本 今天他来了
<?php

/**
* 阿里云盘自动签到
*/
class AlyPanAutoSign
{
    protected $refresh_token = '';
    protected $access_token= '';
    protected $user_name   = '';
    protected $user          = [];

    public function __construct($refresh_token = '')
    {
      if ($refresh_token) $this->setRefreshToken($refresh_token);
    }

    /**
   * CURL发送Request请求,含POST和REQUEST
   * @Param string $url    请求的链接
   * @param mixed$params 传递的参数
   * @param string $method 请求的方法
   * @param array$header 请求头
   * @Return array
   */
    protected function sendRequest($url, $params = [], $method = 'POST', $header = [])
    {
      $method = strtoupper($method);
      $protocol = substr($url, 0, 5);
      $query_string = is_array($params) ? http_build_query($params) : $params;

      $ch = curl_init();
      $defaults = [];
      if ('GET' == $method) {
            $geturl = $query_string ? $url . (stripos($url, "?") !== false ? "&" : "?") . $query_string : $url;
            $defaults = $geturl;
      } else {
            $defaults = $url;
            if ($method == 'POST') {
                $defaults = 1;
            } else {
                $defaults = $method;
            }
            $defaults = $params;
      }

      $defaults = false;
      $defaults = "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/45.0.2454.98 Safari/537.36";
      $defaults = true;
      $defaults = true;
      $defaults = 3;
      $defaults = 3;

      // disable 100-continue
      curl_setopt($ch, CURLOPT_HTTPHEADER, $header);

      if ('https' == $protocol) {
            $defaults = false;
            $defaults = false;
      }

      curl_setopt_array($ch, $defaults);

      $ret = curl_exec($ch);
      $err = curl_error($ch);

      if (false === $ret || !empty($err)) {
            $errno = curl_errno($ch);
            $info = curl_getinfo($ch);
            curl_close($ch);
            return [
                'ret'   => false,
                'errno' => $errno,
                'msg'   => $err,
                'info'=> $info,
            ];
      }
      curl_close($ch);
      return [
            'ret' => true,
            'msg' => $ret,
      ];
    }

    protected function writeln($msg)
    {

      if (PHP_SAPI == 'cli') {
            echo "$msg\n";
      } else {
            echo "$msg </br>";
      }
    }

    protected function error($msg)
    {
      if (PHP_SAPI == 'cli') {
            echo "<error>$msg</error>\n";
      } else {
            echo "<span style='color: red'>$msg</span><br>";
      }
      die;
    }

    protected function success($msg)
    {
      if (PHP_SAPI == 'cli') {
            echo "<success>$msg</success>\n";
      } else {
            echo "<span style='color: green'>$msg</span><br>";
      }
      die;
    }

    public function setRefreshToken($refresh_token = '')
    {
      $this->refresh_token = $refresh_token;
      return $this;
    }

    /**
   * 获取用户信息
   */
    protected function getAccessToken()
    {
      try {
            $res = $this->sendRequest("https://auth.aliyundrive.com/v2/account/token", json_encode([
                'grant_type'    => 'refresh_token',
                'refresh_token' => $this->refresh_token,
            ]), 'POST', ['Content-Type: application/json',]);
            if (!$res['ret']) $this->error("获取access_token失败");
            $data = json_decode($res['msg'], true);
            if (isset($data['message'])) $this->writeln($data['message']);
            if (!isset($data['access_token'])) $this->error("refresh_token异常,获取access_token失败 可能是refresh_token过期");
            $this->access_token = $data['access_token'];
            $this->user_name = $data['nick_name'] . ":" . $data['user_name'];
            $this->user = $data;
            $this->writeln($this->user_name . " ---登录成功---");
      } catch (Exception $e) {
            $this->error("程序错误:" . $e->getMessage());
      }
    }

    /**
   * 签到
   */
    protected function signIn()
    {
      if (!$this->user) $this->error("请登录!!!");
      try {
            $res = $this->sendRequest("https://member.aliyundrive.com/v1/activity/sign_in_list", json_encode([
                "_rx-s" => "mobile",
            ]), 'POST', ['Content-Type: application/json', "Authorization: Bearer $this->access_token"]);
            if (!$res['ret']) $this->error("请求签到失败");
            $data = json_decode($res['msg'], true);
            if (isset($data['message'])) $this->writeln($data['message']);
            if (!isset($data['result']['signInCount'])) $this->error("签到失败");
            $this->writeln("---$this->user_name 签到成功,本月累计签到{$data['result']['signInCount']}次---");
            $this->user['signInCount'] = $data['result']['signInCount'];
      } catch (Exception $e) {
            $this->error("程序错误:" . $e->getMessage());
      }
    }

    /**
   * 领取签到奖励
   */
    protected function receiveSignInReward()
    {
      if (!$this->user) $this->error("请登录!!!");
      try {
            $res = $this->sendRequest("https://member.aliyundrive.com/v1/activity/sign_in_reward?_rx-s=mobile'", json_encode([
                'signInDay' => $this->user['signInCount'],
            ]), 'POST', ['Content-Type: application/json', "Authorization: Bearer $this->access_token"]);
            if (!$res['ret']) $this->error("请求获取奖励失败");
            $data = json_decode($res['msg'], true);
            if (isset($data['message'])) $this->writeln($data['message']);
            if (!isset($data['result']['notice'])) $this->error("签到失败");
            $this->writeln("---$this->user_name 领取奖励成功,{$data['result']['name']}-{$data['result']['description']}-{$data['result']['notice']}---");
      } catch (Exception $e) {
            $this->error("程序错误:" . $e->getMessage());
      }
    }

    public function run($refresh_token = '')
    {
      if ($refresh_token) $this->refresh_token = $refresh_token;
      $this->getAccessToken();
      $this->signIn();
      $this->receiveSignInReward();
    }
}

(new AlyPanAutoSign)->setRefreshToken("你的refresh_token")->run();

PHP版本亲测7.2可用 其它版本按理都是通用的

RefreshToken获取方法网上一堆我就不重复了
(本人php小白 大佬们轻点 温柔点 那里不可以!!! 也不是不行 就一次哦)

------------------------------------------------------------------------------------
问:refresh_token填哪?
答:在脚本的最后(new AlyPanAutoSign)->setRefreshToken("你的refresh_token")->run(); 这里填入你的refresh_token。

坐久落花多 发表于 2023-12-14 17:13

赞!要是wps那个不行了,我就换这个

moyefu 发表于 2023-12-15 09:19

1997mtnh 发表于 2023-12-14 19:11
The input parameter refresh_token is not valid.
refresh_token异常,获取access_token失败 可能是refre ...

在脚本最后一行
(new AlyPanAutoSign)->setRefreshToken("你的Token")->run();
把你的refresh_token填到你的Token里面就行

moyefu 发表于 2024-6-5 13:21

openJQ 发表于 2024-6-2 00:31
代码好像过期了,,运行提示需要更新最新APP

阿里云盘废了

openJQ 发表于 2024-6-2 00:31

代码好像过期了,,运行提示需要更新最新APP

hmymy2 发表于 2024-3-25 09:24

学习下学习下

moyefu 发表于 2024-3-25 09:05

openJQ 发表于 2024-3-17 11:27
refresh_token是永久有效的吗?

不是 一般一个月左右 时间不固定

openJQ 发表于 2024-3-17 11:27

refresh_token是永久有效的吗?

hh258123 发表于 2024-3-16 15:25

评论会升级吗

shihao2002 发表于 2024-3-15 21:20

不会用啊&#128550;&#128550;

yeyuanxinyi 发表于 2024-3-15 21:03

学到了,让我一个懒人又更懒了

anyway001 发表于 2024-3-14 09:21

学习学习 感谢大佬分享
页: [1] 2 3 4
查看完整版本: PHP阿里云签到脚本