php对接百度网盘开发平台API开发高级实战案例解析:(环境部署、php封装类、Access Token获取、预上传、分片上传)

本文涉及的产品
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
简介: php对接百度网盘开发平台API开发高级实战案例解析:(环境部署、php封装类、Access Token获取、预上传、分片上传)

前言


百度网盘是国民级的个人云盘产品,有着先进安全的云存储与传输技术,通过多年积累沉淀的解决方案,来满足不同行业不同阶段合作伙伴的个性化需求,降低开发和购买成。在开放平台,你可以方便快捷地实现应用、设备与百度网盘的连接互通:数据的上传、网盘文件的管理与下载、场景化的影音与相册服务、开发一个小程序入驻网盘等等能力。


传送门 >> 百度网盘开放平台


一、环境部署

1.封装BdPan类库

封装BdPan.php百度网盘开发类;

class BdPan
{
    const AppID = '303***';
    const Appkey = 'zsBbkMiTO5L86FST***';
    const Secretkey = 'RHwNALMZcLWjluHn***';
    const RedirectUri = 'http://test.com/pan/getcode.php';
    //构造函数
    public function __construct($AppID = '', $Appkey = '', $Secretkey = '')
    {
        $AppID = self::AppID;
        $Appkey = self::Appkey;
        $Secretkey = self::Secretkey;
        //核检常量参数
        $this->check_auth($AppID, $Appkey, $Secretkey);
    }
    //判断Appkey是否为空
    public function check_auth($AppID, $Appkey, $Secretkey)
    {
        if ($AppID == '') {
            die('AppID不能为空');
        }
        if ($Appkey == '') {
            die('Appkey不能为空');
        }
        if ($Secretkey == '') {
            die('Secretkey不能为空');
        }
    }
}


2.回调地址配置

http://test.com/pan/getcode.php,为回调地址:

说明:


授权回调地址支持配置多个,多个地址之间,通过英文逗号进行分隔。

授权回调地址修改后在 1 小时后生效;

对于有 server的应用,您必须配置授权回调地址,用以 OAuth2.0 检验授权请求中的 “redirect_uri” 参数。以便保证 OAuth2.0在回调过程中,会回调到安全域名。

也可传redirect_uri=oob。回调后会返回一个平台提供默认回调地址:http://openapi.baidu.com/oauth/2.0/login_success


二、获取授权码Code

发起授权码 Code 请求,获取用户授权码 Code。

1.手动获取Code

配置链接,格式如下:

    //获取授权码
    public function getCode()
    {
        $state = md5(md5(time()));
        $url = 'http://openapi.baidu.com/oauth/2.0/authorize?response_type=code&client_id=' . self::Appkey . '&redirect_uri=' . self::RedirectUri . '&scope=basic,netdisk&state=' . $state;
        header("Location:" . $url);
    }
require_once "BdPan.php";
//实例化
$pan = new BdPan();
$token = $pan->makeToken();
echo $token;

如浏览器为正常使用百度账户登录,出现下面界面:

redirect uri 值为"oob"

对于采用 Authentication Code方式(即适用于绝大部分WEB/WAP网站获取access token)获取access token,如果redirect uri地址为 “oob”,那么我们会有单独的页面展示授权码,方便用户手动复制粘贴,到第三方应用中的授权码输入框中,以便获取access token。

对于采用 Implicit Grant方式(即适用于javascript等应用获取access token)获取access token,如果redirect uri地址为"oob",那么我们会提供一个单独的地(http://openapi.baidu.com/oauth/2.0/login_success),后面加#号跟上相应的返回参数。


2.生成本地token

web端获取Code,以PHP为例:

 //生成本地令牌token
    public function makeToken()
    {
        $code = $_GET['code'];
        if (empty($code)) {
            die('授权失败');
        }
        $url = 'https://openapi.baidu.com/oauth/2.0/token?grant_type=authorization_code&code=' . $code . '&client_id=' . self::Appkey . '&client_secret=' . self::Secretkey . '&redirect_uri=' . self::RedirectUri;
        //保存为本地文件;
        $res = json_decode(self::httpGet($url), true);
        $data = array();
        $data['access_token'] = $res['access_token'];
        $data['refresh_token'] = $res['refresh_token'];
        $data['expires_in'] = $res['expires_in'];
        $data['expires'] = time() + $res['expires_in'];
        $jsonStr = json_encode($data);
        $fp = fopen("./data/access_token.json", "w");
        fwrite($fp, $jsonStr);
        fclose($fp);
        return $jsonStr;
    }


3.读取AccessToken凭证

 /**
     * 读取本地$access_token
     */
    public function getToken()
    {
        $file = file_get_contents("./data/access_token.json", true);
        $result = json_decode($file, true);
        if ($result['access_token'] == NULL || time() > $result['expires']) {
            //过期或不存在时,再次生成新的$code
            //header("Location:./index.php");
        } else {
            return $result['access_token'];
        }
    }


4.函数

爬取函数

   private function httpGet($url)
    {
        $curl = curl_init();
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($curl, CURLOPT_TIMEOUT, 500);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, true);
        curl_setopt($curl, CURLOPT_URL, $url);
        $res = curl_exec($curl);
        curl_close($curl);
        return $res;
    }


RequestBody参数传递

public function curlPost($url, $data = array())
    {
        $ch = curl_init();
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE);
        curl_setopt($ch, CURLOPT_POST, 1);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
        $output = curl_exec($ch);
        curl_close($ch);
        return $output;
    }


二、简化模式授权

简化模式不需要获取授权码 Code,直接获取 Access Token 凭证。简化模式不支持刷新 Access Token,过期后需用户重新登录授权。简化模式适用于无 server 端配合的应用。


平台提供了一种默认的redirect uri参数为 “oob”,回调后会返回一个平台提供默认回调地址(http://openapi.baidu.com/oauth/2.0/login_success ),例如:


http://openapi.baidu.com/oauth/2.0/login_success#expires_in=86400&access_token=1.79b233866fb427d6bb7f0651947b5591.86400.1311151425.3238112329-131640&session_secret=1c07e054952628711b61228f44f46332&session_key=9XMZMoWRoE6Or%2BHLlFGhB1%2FBH2l3Jzi2CLOxIVVbcAMnUT8tyKeNiyF6oPQESDa9UTcD0uYuYtULwe3LbqKNvc90wOkY&scope=basic


三、网盘基础服务

1.获取用户信息

    public function getUserInfo()
    {
        $access_token = $this->getToken();
        $user_info = 'https://pan.baidu.com/rest/2.0/xpan/nas?method=uinfo&access_token=' . $access_token;
        return self::httpGet($user_info);
    }

2.获取网盘容量信息

    public function getQuota()
    {
        $access_token = $this->getToken();
        $user_info = 'https://pan.baidu.com/api/quota?access_token=' . $access_token;
        return self::httpGet($user_info);
    }


3.递归获取文件列表

    public function getDirList()
    {
        $access_token = $this->getToken();
        $res = 'https://pan.baidu.com/rest/2.0/xpan/file?method=list&access_token=' . $access_token;
        return self::httpGet($res);
    }


4.预上传

    //
    public function precreate()
    {
        $access_token = $this->getToken();
        $data = array(
            'path' => '/apps/1.pdf',
            'size' => filesize("upload/1.pdf"),
            'rtype' => 3,
            'isdir' => 0,
            'autoinit' => 1,
            'block_list' => json_encode([md5('1.pdf')])
        );
        $url = 'https://pan.baidu.com/rest/2.0/xpan/file?method=precreate&access_token=' . $access_token;
        return $this->curlPost($url, $data);
    }


5.分片上传

    //
    public function superfile()
    {
        $access_token = $this->getToken();
        $params = json_decode($this->precreate(), true);
        $data = [
            'type' => 'tmpfile',
            'path' => $params['path'],
            'uploadid' => $params['uploadid'],
            'partseq' => 0,
            'block_list' => json_encode([md5('1.pdf')])//分片上传必须参数
        ];
        //拼接url
        $url = 'https://d.pcs.baidu.com/rest/2.0/pcs/superfile2?method=upload&access_token=' . $access_token . '&';
        $url .= http_build_query($data);
        $file = ['upload/1.pdf'];//本地要上传的文件
        return $this->curlPost($url, $file);
    }


6.创建文件

   //创建文件
    public function createfile()
    {
        $access_token = $this->getToken();
        $params = json_decode($this->precreate(), true);
        $params2 = json_decode($this->superfile(), true);
        $data = [
            'path' => $params['path'],
            'size' => filesize("upload/1.pdf"),
            'isdir' => 0,
            'rtype' => 3,
            'block_list' => json_encode([$params2["md5"]]),
            'uploadid' => $params['uploadid']
        ];
        $url = 'https://pan.baidu.com/rest/2.0/xpan/file?method=create&access_token=' . $access_token;
        return $this->curlPost($url, $data);
    }


成功响应返回参数:


总结

  1. 其中创建文件部分在实际开发中未成功,一直提示errno=2,即参数错误。当注释掉size时,会正常返回参数,但是上传文件却是0B;
        $data = [
            'path' => $params['path'],
            //'size' => filesize("upload/1.pdf"),
            'isdir' => 0,
            'rtype' => 3,
            'block_list' => json_encode([$params2["md5"]]),
            'uploadid' => $params['uploadid']
        ];


  1. 翻阅了CSDN和php相关的百度网盘开发,尚未找出对应的解决方案;百度开发平台的技术文档也几经咀嚼,仍一无所获。
  2. 为了不影响正常的开发进度,暂时留坑吧。

@漏刻有时

相关文章
|
1月前
|
API 数据处理 开发者
获取淘宝分类详情:深入解析taobao.cat_get API接口
淘宝开放平台推出的`taobao.cat_get` API接口,帮助开发者和商家获取淘宝、天猫的商品分类详情。该接口支持获取类目列表、属性及父类目信息,通过指定分类ID(cid)实现精准查询,并提供灵活的参数设置和高效的数据处理。使用流程包括注册账号、创建应用、获取App Key/Secret、构造请求、发送并解析响应。示例代码展示了如何用Python调用此API。开发者可借此为电商项目提供数据支持。
|
12天前
|
数据采集 监控 搜索推荐
深度解析淘宝商品详情API接口:解锁电商数据新维度,驱动业务增长
淘宝商品详情API接口,是淘宝开放平台为第三方开发者提供的一套用于获取淘宝、天猫等电商平台商品详细信息的应用程序接口。该接口涵盖了商品的基本信息(如标题、价格、图片)、属性参数、库存状况、销量评价、物流信息等,是电商企业实现商品管理、市场分析、营销策略制定等功能的得力助手。
|
9天前
|
XML API 开发者
使用 API 接口获取京东商品详情全解析
京东作为头部电商平台,其商品数据极具价值。开发者可通过API接口获取商品详情、订单数据等信息,满足各种业务需求。使用前需注册账号并创建应用获取App Key和App Secret。调用流程包括认证授权、构建请求、发送请求及处理响应。注意事项包括遵守平台规则、控制调用频率和确保数据时效性。通过这些步骤,可为电商数据分析提供有力支持。
|
21天前
|
IDE JavaScript API
1688寻源通API对接流程以及说明
1688寻源通API(这里主要指的是跨境寻原通数据接口)的对接流程及说明如下:
|
29天前
|
JSON 缓存 API
解析电商商品详情API接口系列,json数据示例参考
电商商品详情API接口是电商平台的重要组成部分,提供了商品的详细信息,支持用户进行商品浏览和购买决策。通过合理的API设计和优化,可以提升系统性能和用户体验。希望本文的解析和示例能够为开发者提供参考,帮助构建高效、可靠的电商系统。
39 12
|
21天前
|
搜索推荐 API 开发者
深度解析:利用商品详情 API 接口实现数据获取与应用
在电商蓬勃发展的今天,数据成为驱动业务增长的核心。商品详情API接口作为连接海量商品数据的桥梁,帮助运营者、商家和开发者获取精准的商品信息(如价格、描述、图片、评价等),优化策略、提升用户体验。通过理解API概念、工作原理及不同平台特点,掌握获取权限、构建请求、处理响应和错误的方法,可以将数据应用于商品展示、数据分析、竞品分析和个性化推荐等场景,助力电商创新与发展。未来,随着技术进步,API接口将与人工智能、大数据深度融合,带来更多变革。
62 3
|
27天前
|
数据挖掘 API 数据安全/隐私保护
深度解析:获取亚马逊畅销榜API接口及实战应用
Lazada 淘宝详情 API 是连接 Lazada 和淘宝商品数据的桥梁,帮助电商从业者获取淘宝商品的详细信息(如标题、描述、价格等),并应用于 Lazada 平台。它在市场调研、产品选品、价格策略和数据分析等方面为商家提供支持,助力优化运营策略。通过 Python 示例代码展示了 API 的实际应用,并强调了数据准确性、API 使用限制及数据安全的重要性。
52 10
|
1月前
|
供应链 搜索推荐 API
深度解析1688 API对电商的影响与实战应用
在全球电子商务迅猛发展的背景下,1688作为知名的B2B电商平台,为中小企业提供商品批发、分销、供应链管理等一站式服务,并通过开放的API接口,为开发者和电商企业提供数据资源和功能支持。本文将深入解析1688 API的功能(如商品搜索、详情、订单管理等)、应用场景(如商品展示、搜索优化、交易管理和用户行为分析)、收益分析(如流量增长、销售提升、库存优化和成本降低)及实际案例,帮助电商从业者提升运营效率和商业收益。
184 20
|
2月前
|
PHP 开发者 容器
PHP命名空间深度解析:避免命名冲突与提升代码组织####
本文深入探讨了PHP中命名空间的概念、用途及最佳实践,揭示其在解决全局命名冲突、提高代码可维护性方面的重要性。通过生动实例和详尽分析,本文将帮助开发者有效利用命名空间来优化大型项目结构,确保代码的清晰与高效。 ####
72 20
|
2月前
|
运维 数据库连接 PHP
PHP中的异常处理机制深度解析####
本文深入探讨了PHP中异常处理机制的工作原理,通过实例分析展示了如何有效地使用try-catch语句来捕获和处理运行时错误。我们将从基础概念出发,逐步深入到高级应用技巧,旨在帮助开发者更好地理解和利用这一强大的工具,以提高代码的稳定性和可维护性。 ####

推荐镜像

更多