1. 设备认证

1.1.1. WebSocket方式

AuthRequest

参数 类型 描述 默认值
key string 开放接口Key,在开放平台语音接入获取 无,必填
device_type_id string 设备类型ID 无,必填
device_id string 设备ID,开发者平台默认赠送10个sn,请选择任意一个 无,必填
service string tts 或 speech 无,必填
version string 接口版本号 无,必填
timestamp string unix时间戳 无,必填
sign string 由以上几项及 secret 按约定的加密方式生成 无,必填
说明
  1. 字段 sign 计算方法:

    1. 拼成如下字符串 utf8 的字符串:key={key}&device_type_id={device_type_id}&device_id={device_id}&service={service}&version={version}&time={time}&secret={secret},其中 :
    2. 计算 str 字符串的 md5 值
  2. 字段 version 有 1.0 或 2.0,分别对应 协议地址 中 v1 或 v2 目录,目前支持的协议版本:

    • 语音识别: serivce(speech), version(2)
    • 语音合成 :serivce(tts), version(1)

AuthResponse

参数 类型 描述
result int32 认证结果(成功:0, 失败:-1)
说明
  1. 当认证失败时,服务端会主动断开此连接。
  2. 确保device_id是经过认证的sn,开发者平台里面默认赠送10个认证sn,用于测试。

1.1.2. HTTP方式

Authorization

设备认证方式中的Authorization Header内容格式如下:

version={version};time={time};sign={sign};key={key};device_type_id={device_type_id};device_id={device_id};service={service}

Signature

需要根据time字段实时计算,Authorization中的sign字段是签名串,是对下列组合的字符串(UTF-8编码)做MD5计算

key={key}&device_type_id={device_type_id}&device_id={device_id}&service={service}&version={version}&time={time}&secret={secret}

生成sign示例代码(golang)


func generateAuthorization(version, secret, key, deviceTypeID, deviceID, service string) string {
    now := strconv.FormatInt(time.Now().Unix(), 10)
    return fmt.Sprintf("version=%s;time=%s;sign=%s;key=%s;device_type_id=%s;device_id=%s;service=%s",
        version, now, generateSign(now, version, secret, key, deviceTypeID, deviceID, service),
        key, deviceTypeID, deviceID, service)
}

func generateSign(now, version, secret, key, deviceTypeID, deviceID, service string) string {
    src := "key=" + key + "&device_type_id=" + deviceTypeID + "&device_id=" + deviceID + "&service=" + service + "&version=" + version + "&time=" + now + "&secret=" + secret
    fmt.Println("sign source:", src)
    sign := strings.ToUpper(makeMD5(src))
    fmt.Println("sign:", sign)
    return sign
}

func makeMD5(data string) string {
    h := md5.New()
    h.Write([]byte(data))
    return hex.EncodeToString(h.Sum(nil))
}

results matching ""

    No results matching ""