加载中...

【PHP】抖音授权登录并获取用户公开信息(网页)

【PHP】抖音授权登录并获取用户公开信息(网页)

抖音官方文档:https://open.douyin.com/platform/doc/OpenAPI-oauth2

抖音的官方文档和接口及其随意。。。。

调用流程包括:

  1. 第三方发起抖音授权登录请求,抖音用户允许授权第三方应用后(扫码确认或账号密码授权登录),确认通过后,会重定向到第三方网站(回调接口)。并且附带授权临时票据(code)

  2. 第三方通过code参数,以及ClientKey和ClientSecret等参数,通过API换取access_token

  3. 通过access_token进行接口调用,获取用户基本信息及其他操作等。

一、注册账号

在抖音开放平台注册账号 ,网址:https://open.douyin.com/platform

 

二、创建应用

New Image

填写信息,然后提交,提交之后需要审核

New Image

 

三、查看应用

在《管理中心》可以查看应用信息

New Image

审核通过之后会得到Client Key和Client Secret,调用接口时需要使用

四、应用详情

在“接口权限”申请需要使用的权限

 

New Image

在“特殊权限”中申请“静默授权”,用来获取用户的open_id,open_id是用户在该平台的唯一标识

New Image

五、获取登录二维码

获取授权码(code)

请求方式:GET​

请求链接:https://open.douyin.com/platform/oauth/connect/

    

名称类型必填说明

client_key 

 

string应用唯一标识

response_type 

 

string

填写code

Available values : code

scope 

 

string应用授权作用域,多个授权作用域以英文逗号(,)分隔

redirect_uri 

 

string授权成功后的回调地址,必须以http/https开头。

state

 

string用于保持请求和回调的状态
  1. public function GetLoginQrcode()
  2. {
  3. $url = $this->url . ''/platform/oauth/connect'';
  4. $redirect_uri = "回调地址";
  5. $scope = "scope";
  6. $url = $url . "?client_key=" . $this->key . "&response_type=code&scope=" . $scope . "&redirect_uri=" . $redirect_uri . "&state=1";
  7. header(''Location:'' . $url);
  8. exit();
  9. }

New Image

用户允许授权后,将会重定向到redirect_uri的网址上,并且带上code和state参数

New Image

 

六、获取用户公开信息

获取用户公开信息

请求方式:GET​

请求链接:https://open.douyin.com/oauth/userinfo/

名称类型必填说明
access_tokenstring调用/oauth/access_token/生成的token,此token需要用户授权
open_idstring通过/oauth/access_token/获取,用户唯一标志

要获取用户公开信息,需要先获取access_token和open_id

获取access_token和open_id:

获取用户公开信息

请求方式:GET​

请求链接:https://open.douyin.com/oauth/access_token/

名称类型必填说明

client_key 

string应用唯一标识
client_secretstring应用唯一标识对应的密钥
codestring授权码。即/oauth/connect/回调时返回的code
grant_typestring写死"authorization_code"即可
  1. public function get_access_token($code)
  2. {
  3. $url = $this->url . ''/oauth/access_token/'';
  4. $params = array(
  5. ''client_key'' => $this->key,
  6. ''client_secret'' => $this->secret,
  7. ''code'' => $code,
  8. ''grant_type'' => ''authorization_code'',
  9. );
  10. $data = $this->curl_post($url, $params);
  11. return $data;
  12. }

curl_post方法:https://blog.csdn.net/I_lost/article/details/104518356

返回数据:

New Image

根据access_token和open_id获取用户信息:

  1. public function getUserInfo($access_token, $openid)
  2. {
  3. $url = $this->url . ''/oauth/userinfo/'';
  4. $params = array(
  5. ''access_token'' => $access_token,
  6. ''open_id'' => $openid
  7. );
  8. $result = $this->curl_post($url, $params);
  9. return $result;
  10. }

返回数据:

New Image

公用接口返回数据极少,详细数据可使用99接口(http://www.99api.com/comm_details?id=2034),但是需付费,且和抖音官方接口返回数据无法判断是否是同一个用户。

七、刷新access_token

  1. 刷新access_token
  2. 请求方式:GET​
  3. 请求链接:https://open.douyin.com/oauth/refresh_token/
名称类型必填说明

client_key 

string应用唯一标识
refresh_tokenstring填写通过access_token获取到的refresh_token参数
grant_typestring填refresh_token
  1. public function refresh_token($refresh_token)
  2. {
  3. $url = $this->url . ''/oauth/refresh_token/'';
  4. $params = array(
  5. ''client_key'' => $this->key,
  6. ''grant_type'' => "refresh_token",
  7. ''refresh_token'' => $refresh_token,
  8. );
  9. $result = $this->curl_get($url, $params);
  10. return $result;
  11. }

 

八、关于access_token和refresh_token的有效期

官方文档:

当access_token过期(过期时间15天)后,可以通过该接口使用refresh_token(过期时间30天)进行刷新:

1. 若access_token已过期,调用接口会报错(error_code=10008或2190008),refresh_token后会获取一个新的  access_token以及新的超时时间。
2. 若access_token未过期,refresh_token不会改变原来的access_token,但超时时间会更新,相当于续期。
3. 若refresh_token过期,获取access_token会报错(error_code=10010),此时需要重新走用户授权流程。