PHP百度小程序rtc-room组件token获取经历

【前言】

目前就职盘古网络集团,一名PHPer程序员。我们的主营业务是百度产品相关,所以最近有了一个百度小程序项目,涉及其音视频组件做直播。

 开发文档

百度智能小程序文档

 鉴权token

百度智能小程序文档

 嗯,很好的功能。结果测试发现本地端画面没问题,然而远端画面黑屏。百度搜索没相关信息,社区贴子就一个,嗯很好。然后我就做了那个挖坑埋自己的事(发帖吧)。

智能小程序开发者社区

 经过漫长的世纪,给我的结果是我点背,申请小程序时其版本是V1,现在是V2了。他们给我处理了下就可以了,我真爱你。。。

废话不多说,文档示例中有go、java、python、偏偏没有php的。

 这你敢看?

经过我多年的php经验按照这个自写了一个类,分享给大家

<?php

namespace baiduapp;
const BASELEN = 50;

class BaiDuLive {
    public $token_version = 2;          // token版本字段
    public function __toString() {
        return get_class($this) . ': ' . print_r($this, true);
    }
    public function gen($app_id, $app_secret, $uid, $parameter, $privileges, $build_timestamp, $valid_time) {
        $uid_bytes = pack('n', strlen($uid)) . $uid;
        $parameter_bytes = '';
        foreach ($parameter as $k => $v) {
            $parameter_bytes .= pack('n', strlen($k)) . $k . pack('n', strlen($v)) . $v;
        }
        $privileges_bytes = '';
        foreach ($privileges as $k => $v) {
            $privileges_bytes .= pack('n', strlen($k)) . $k . pack('J', $v);
        }
        $token_len = BASELEN + strlen($uid) + strlen($parameter_bytes) + strlen($privileges_bytes);
        $barray = pack('NNN', $this->token_version, intval($token_len), intval($app_id)) .
            $uid_bytes .
            pack('n', count($parameter)) .
            $parameter_bytes .
            pack('n', count($privileges)) .
            $privileges_bytes .
            pack('N', intval($build_timestamp / 4294967296)) .
            pack('N', intval($build_timestamp % 4294967296)) .
            pack('N', intval($valid_time));
        $mac = hash_hmac('sha1', $barray, $app_secret, true);
        $barray .= $mac;
        return rtrim(strtr(base64_encode($barray), '+/', '-_'), '=');
    }
}

//$test = new BaiDuLive();
//$app_id = 后台提供appid;
//$app_secret = 后台提供秘钥;
//$uid = "456789"; //用户id
//$valid_time = 43200; //到期时间,注意不是时间戳,是秒,会根据build_timestamp相加
//$build_timestamp = time() * 1000; //13位当前时间戳
//$parameter = array();
//$privileges = array();
//$res = $test->gen($app_id, $app_secret, $uid, $parameter, $privileges, $build_timestamp, $valid_time);
//var_dump($res);

可以看到大量采用pack来转换数据,诶不想吐槽了,一加密鉴权至于么? 

 新版的音视频后台配置流程

 

 它会单独提供appid和秘钥。至于想测试生成出来的token是否正确,可以去文档下载一个你会的语言示例,它里面有鉴权测试。

 有意思的是,它python是2版本的。。。真老,我又根据python3改了下,不然报错。

php的生成然后扔它示例里的鉴权测试下没问题,有意思的是我的第一版php的发现生成出来和python的示例token不一致,同时间戳下,能鉴权通过,不过解析出来的build_timestamp是负数,因为php整型溢出了擦。

总结

总之这是一个磨人的经历,我将这个经历故事和代码给大家分享出来,为其他的玩百度小程序rtc-room的少爬坑吧。我上面的代码直接用就行。诶都是泪,我爱百度。

猜你喜欢

转载自blog.csdn.net/weixin_47723549/article/details/131900084