前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >腾讯云ASR产品-PHP实现录音文件识别极速版鉴权请求

腾讯云ASR产品-PHP实现录音文件识别极速版鉴权请求

原创
作者头像
HI hero
发布2021-10-11 17:27:49
6.2K13
发布2021-10-11 17:27:49
举报

一、准备工作

(1)开通腾讯云 https://cloud.tencent.com/

(2)腾讯云控制台开通实时语音权限 https://console.cloud.tencent.com/asr

(3)控制台设置秘钥 https://console.cloud.tencent.com/cam/capi

内容

说明

支持语言

中文普通话

音频格式

wav、pcm、ogg-opus、speex、silk、mp3、m4a、aac

使用限制

支持100MB以内音频文件的识别

请求协议

HTTPS

请求地址

https://asr.cloud.tencent.com/asr/flash/v1/<appid>?{请求参数}

二、代码

代码语言:javascript
复制
<?php

//极速版录音文件识别
class SpeedVoice
{
    //腾讯云密钥信息 需要配置
    const APPID = "您的APPID";
    const SECRET_ID = "您的SECRET_ID";
    const SECRET_KEY = "您的SECRET_KEY";

    const AGREEMENT = "https";
    const VOICE_URL = "asr.cloud.tencent.com/asr/flash/v1/";
    const HTTPRequestMethod = "POST";
    //引擎模型类型。8k_zh:8k 中文普通话通用;16k_zh:16k 中文普通话通用;16k_en:16k 英语;16k_zh_video:16k 音视频领域。
    static $ENGINE_MODEL_TYPE = '16k_zh';

    //结果返回方式 0:同步返回,拿到全部中间结果, or 1:尾包返回
    static $RES_TYPE = 1;

    // 支持 wav、pcm、ogg-opus、speex、silk、mp3、m4a、aac。
    static $VOICE_FORMAT = 'mp3';

    //是否开启说话人分离
    static $SPEAKER_DIARIZATION = 0;
    //后处理参数
    static $FILTER_DIRTY = 0;
    static $FILTER_MODAL = 0;
    static $FILTER_PUNC = 0;
    static $CONVERT_NUM_MODE = 1;
    static $WORD_INFO = 0;
    static $FIRST_CHANNEL_ONLY = 1;


    public static function voice($pathFile)
    {
        //get请求 设置url参数
        $timestamp = time();

        $httpUrlParams =
            [
                "appid" => self::APPID,
                "secretid" => self::SECRET_ID,
                "engine_type" => self::$ENGINE_MODEL_TYPE,
                "voice_format" => self::$VOICE_FORMAT,
                "timestamp" => $timestamp,
                "speaker_diarization"  => self::$SPEAKER_DIARIZATION,
                "filter_dirty"  => self::$FILTER_DIRTY,
                "filter_modal"  => self::$FILTER_MODAL,
                "filter_punc"   => self::$FILTER_PUNC,
                "convert_num_mode"  => self::$CONVERT_NUM_MODE,
                "word_info" => self::$WORD_INFO,
                "first_channel_only" => self::$FIRST_CHANNEL_ONLY
        ];
        //get请求url拼接
        $requestUrl = self::AGREEMENT . "://" . self::VOICE_URL . self::APPID . "?";
        //剔除appid
        unset($httpUrlParams["appid"]);
        //生成URL请求地址
        $requestUrl .= http_build_query($httpUrlParams);
        //鉴权
        $sign = self::getAuthorizationString($httpUrlParams);

        //分片数据包
        $sectionData = file_get_contents($pathFile);
        $headers = [
            'Host: asr.cloud.tencent.com',
            'Content-Type: application/octet-stream',
            'Authorization: ' . $sign,
            'Content-Length: ' . strlen($sectionData),
        ];
        $result = self::get_curl_request($requestUrl, $sectionData, 'POST', $headers);
        print_r($result);
    }


    /**
     * 发送请求
     * @param $url
     * @param array $param
     * @param string $mothod
     * @param array $headers
     * @param int $return_status
     * @param int $flag 关闭https证书
     * @return array|bool|string
     */
    static private function get_curl_request($url, $param, $mothod = 'POST', $headers = [], $return_status = 0, $flag = 0)
    {
        $ch = curl_init();
        if (!$flag) {
            curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
        }

        curl_setopt($ch, CURLOPT_TIMEOUT, 60);

        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
        if (strtolower($mothod) == 'post') {
            curl_setopt($ch, CURLOPT_POST, true);
            curl_setopt($ch, CURLOPT_POSTFIELDS, $param);
        } else {
            $url = $url . "?" . http_build_query($param);
        }
        curl_setopt($ch, CURLOPT_URL, $url);
        curl_setopt($ch, CURLOPT_FOLLOWLOCATION, 2);
        curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

        $ret = curl_exec($ch);
        $code = curl_getinfo($ch);
        curl_close($ch);
        if ($return_status == "1") {
            return array($ret, $code);
        }
        return $ret;
    }

    /**
     * 生成随机字符串
     * @param $len
     * @param bool $special 是否开启特殊字符
     * @return string
     */
    private static function getRandomString($len, $special = false)
    {
        $chars = array(
            "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k",
            "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v",
            "w", "x", "y", "z", "A", "B", "C", "D", "E", "F", "G",
            "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R",
            "S", "T", "U", "V", "W", "X", "Y", "Z", "0", "1", "2",
            "3", "4", "5", "6", "7", "8", "9"
        );

        if ($special) {
            $chars = array_merge($chars, array(
                "!", "@", "#", "$", "?", "|", "{", "/", ":", ";",
                "%", "^", "&", "*", "(", ")", "-", "_", "[", "]",
                "}", "<", ">", "~", "+", "=", ",", "."
            ));
        }

        $charsLen = count($chars) - 1;
        shuffle($chars);                            //打乱数组顺序
        $str = '';
        for ($i = 0; $i < $len; $i++) {
            $str .= $chars[mt_rand(0, $charsLen)];    //随机取出一位
        }
        return $str;
    }

    /**
     * 创建签名
     * @param $params array 提交参数数组
     * @return string
     */
    private static function getAuthorizationString($params)
    {
        //加密字符串拼接
        $signString = self::HTTPRequestMethod . self::VOICE_URL . self::APPID . "?";
        //排序
        ksort($params, SORT_STRING);
        //去除appid
        unset($params["appid"]);
        //转url
        $signString .= http_build_query($params);
        $sign = base64_encode(hash_hmac('SHA1', $signString, self::SECRET_KEY, true));
        return $sign;
    }
}
//请求示例
SpeedVoice::$VOICE_FORMAT = "wav";
SpeedVoice::voice("./0914.wav");

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、准备工作
  • 二、代码
相关产品与服务
语音识别
腾讯云语音识别(Automatic Speech Recognition,ASR)是将语音转化成文字的PaaS产品,为企业提供精准而极具性价比的识别服务。被微信、王者荣耀、腾讯视频等大量业务使用,适用于录音质检、会议实时转写、语音输入法等多个场景。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档