首頁  >  文章  >  後端開發  >  支付寶app登入授權的infoStr授權登入流程

支付寶app登入授權的infoStr授權登入流程

藏色散人
藏色散人轉載
2019-09-06 11:14:356880瀏覽

官網:

服務端sdk:https://docs.open.alipay.com/54/103419/

客戶端如何使用登入:https://docs.open .alipay.com/218/105329/

app授權登入流程:

服务端先拿到 App 端 调用 支付宝 SDK 所需要的 infoStr
App 端 通过 infoStr 获得用户 授权 code
服务端通过 授权 code 拿到请求 token
服务端通过 token 获得用户信息

支付寶app登入授權的infoStr授權登入流程

##app端支付寶登陸步驟:

1.後端傳infoStr

官方是這樣寫的:https://docs.open.alipay.com/218/105325/

看到這邊的實例:

apiname=com.alipay.account.auth&app_id=xxxxx&app_name=mc&auth_type=AUTHACCOUNT&biz_type=openservice&method=alipay.open.auth.sdk.code.get&pid=xxxxx&product_id=APP_FAST_LOGIN&scope=kuaijie&sign_type=RSA2&target_id=20141225xxxx&sign=fMcp4GtiM6rxSIeFnJCVePJKV43eXrUP86CQgiLhDHH2u%2FdN75eEvmywc2ulkm7qKRetkU9fbVZtJIqFdMJcJ9Yp%2BJI%2FF%2FpESafFR6rB2fRjiQQLGXvxmDGVMjPSxHxVtIqpZy5FDoKUSjQ2%2FILDKpu3%2F%2BtAtm2jRw1rUoMhgt0%3D

剛開始很有自信,找一下sdk有沒有alipay.open.auth.sdk.code.get 這個的方法,但是全域搜尋之後沒有看到這個字樣

然後嘗試著去用這個連線去請求是否會得到這個authcode,但還是失敗了。

心情爆炸了,然後看到一篇博客才知道,我一開始就錯了,原來返回的就只需要後台拼接,不需要請求。

可能剛開始的思路就不正確導致的吧, 折騰了一下午。

引用其他開發人員的話:

支付寶app登入授權的infoStr授權登入流程

#取得infoStr

/**
 * InfoStr APP登录需要的的infostr
 * 
 * @return String
 */
public function infoStr()
{
    $infoStr = http_build_query([
        'apiname' => 'com.alipay.account.auth',
        'method' => 'alipay.open.auth.sdk.code.get',
        'app_id' => $this->app_id,
        'app_name' => 'mc',
        'biz_type' => 'openservice',
        'pid' => $this->pid,
        'product_id' => 'APP_FAST_LOGIN',
        'scope' => 'kuaijie',
        'target_id' => mt_rand(999, 99999), //商户标识该次用户授权请求的ID,该值在商户端应保持唯一
        'auth_type' => 'AUTHACCOUNT', // AUTHACCOUNT代表授权;LOGIN代表登录
        'sign_type' => 'RSA2',
    ]);
    $infoStr .= '&sign='.$this->enRSA2($infoStr);
    return $infoStr;
}
/**
 * enRSA2 RSA加密
 * 
 * @param String $data
 * @return String
 */
private function enRSA2($data)
{
    $str = chunk_split(trim($this->private_key), 64, "\n");
    $key = "-----BEGIN RSA PRIVATE KEY-----\n$str-----END RSA PRIVATE KEY-----\n";
    // $key = file_get_contents(storage_path('rsa_private_key.pem')); 为文件时这样引入
    $signature = '';
    $signature = openssl_sign($data, $signature, $key, OPENSSL_ALGO_SHA256)?base64_encode($signature):NULL;
    return $signature;
}

程式碼來自https:// learnku.com/articles/30076#replies

以上是支付寶app登入授權的infoStr授權登入流程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:csdn.net。如有侵權,請聯絡admin@php.cn刪除