实现效果:
py计算签名
计算签名TRTC文档说明:
文档地址:https://cloud.tencent.com/document/product/647/51586#.E8.AE.A1.E7.AE.97.E7.AD.BE.E5.90.8D
注意:这里的body内容,不要做任何转化,否则会计算签名错误!
回调密钥:
去trtc控制台配置回调密钥,地址:https://console.cloud.tencent.com/trtc
py代码逻辑:(python环境:python3.8)(注:此示例代码仅供参考!)
# -*- coding: utf8 -*-
import hmac
import base64
from hashlib import sha256
# 功能:第三方回调sign校验
# 参数:
# key:控制台配置的密钥key
# body:第三方回调返回的body体
# sign:第三方回调返回的签名值sign
# 返回值:
# Status:OK 表示校验通过,FAIL 表示校验失败,具体原因参考Info
# Info:成功/失败信息
def checkSign(key, body, sign):
temp_dict = {}
computSign = base64.b64encode(hmac.new(key.encode('utf-8'), body.encode('utf-8'), digestmod=sha256).digest()).decode('utf-8')
print("生成的sign为:", computSign)
print("传入的sign为:", sign)
if computSign == sign:
temp_dict['Status'] = 'OK'
temp_dict['Info'] = '校验通过'
return temp_dict
else:
temp_dict['Status'] = 'FAIL'
temp_dict['Info'] = '校验失败'
return temp_dict
if __name__ == '__main__':
key = 'testKey'
message ='{/n/t"EventGroupId":/t1,/n/t"EventType":/t104,/n/t"CallbackTs":/t1634025594562,/n/t"EventInfo":/t{/n/t/t"RoomId":/t"696969",/n/t/t"EventTs":/t1634025594,/n/t/t"EventMsTs":/t1634025594520,/n/t/t"UserId":/t"test10",/n/t/t"UniqueId":/t1634025590938,/n/t/t"Role":/t20,/n/t/t"Reason":/t1/n/t}/n}'
sign = 'ykT+66vvx+Q9tyAEAJIyp5D/zOyPlaSNlsU2MB7InuU='
result = checkSign(key, message, sign)
print(result)
注意:此示例代码仅供参考!
原创文章,作者:kirin,如若转载,请注明出处:https://blog.ytso.com/tech/pnotes/212451.html