最近做的项目,需要接入腾讯云 IM,翻看了一下文档,iOS、Android 以及 Web 端基本上都有 SDK 可以集成。我使用的服务端是用 Python 写的,腾讯 IM 暂时还没有 Python 的官方文档。但是在腾讯云的官方论坛上找到了解决方法。

服务端最基本的一个需求是:使用接入用户的 identifier 和应用申请的腾讯云 appid、私钥等信息,通过指定算法,生成用户用来登录腾讯云 IM 的 usersig。

源代码:#! /usr/bin/python# coding:utf-8import OpenSSL, base64, zlib, json, time

ecdsa_pri_key = """

自己的私钥

"""def list_all_curves():

list = OpenSSL.crypto.get_elliptic_curves()    for element in list:        print elementdef get_secp256k1():

print OpenSSL.crypto.get_elliptic_curve('secp256k1');def base64_encode_url(data):

base64_data = base64.b64encode(data)

base64_data = base64_data.replace('+', '*')

base64_data = base64_data.replace('/', '-')

base64_data = base64_data.replace('=', '_')    return base64_datadef base64_decode_url(base64_data):

base64_data = base64_data.replace('*', '+')

base64_data = base64_data.replace('-', '/')

base64_data = base64_data.replace('_', '=')

raw_data = base64.b64decode(base64_data)    return raw_dataclass TLSSigAPI:

""""""

__acctype = 0

__identifier = ""

__appid3rd = ""

__sdkappid = 0

__version = 20151204

__expire = 3600*24*30       # 默认一个月,需要调整请自行修改

__pri_key = ""

__pub_key = ""

_err_msg = "ok"

def __get_pri_key(self):

return OpenSSL.crypto.load_privatekey(OpenSSL.crypto.FILETYPE_PEM, self.__pri_key);    def __init__(self, sdkappid, pri_key):

self.__sdkappid = sdkappid

self.__pri_key = pri_key    def __create_dict(self):

m = {}

m["TLS.account_type"] = "%d" % self.__acctype

m["TLS.identifier"] = "%s" % self.__identifier

m["TLS.appid_at_3rd"] = "%s" % self.__appid3rd

m["TLS.sdk_appid"] = "%d" % self.__sdkappid

m["TLS.expire_after"] = "%d" % self.__expire

m["TLS.version"] = "%d" % self.__version

m["TLS.time"] = "%d" % time.time()        return m    def __encode_to_fix_str(self, m):

fix_str = "TLS.appid_at_3rd:"+m["TLS.appid_at_3rd"]+"\n" \

+"TLS.account_type:"+m["TLS.account_type"]+"\n" \

+"TLS.identifier:"+m["TLS.identifier"]+"\n" \

+"TLS.sdk_appid:"+m["TLS.sdk_appid"]+"\n" \

+"TLS.time:"+m["TLS.time"]+"\n" \

+"TLS.expire_after:"+m["TLS.expire_after"]+"\n"

return fix_str    def tls_gen_sig(self, identifier):

self.__identifier = identifier

m = self.__create_dict()

fix_str = self.__encode_to_fix_str(m)

pk_loaded = self.__get_pri_key()

sig_field = OpenSSL.crypto.sign(pk_loaded, fix_str, "sha256");

sig_field_base64 = base64.b64encode(sig_field)

m["TLS.sig"] = sig_field_base64

json_str = json.dumps(m)

sig_cmpressed = zlib.compress(json_str)

base64_sig = base64_encode_url(sig_cmpressed)        return base64_sig

def main():

api = TLSSigAPI(1400001052, ecdsa_pri_key)

sig = api.tls_gen_sig("xiaojun")    print sigif __name__ == "__main__":

main()

过程:将用户的信息组装成一个字符串(json格式的,是直接拼装的,因为顺序不能乱),是哪些信息,可以看 __encode_to_fix_str;

使用 sha256 将字符串 hash,然后再用私钥签名,一般加密接口都会一把搞定,加密曲线使用的是 secp256k1;

把第2步得到的缓冲区进行 base64;

将所有用户的信息以及第3步得到签名写进一个 json 串,此时可以不论顺序;

将 json 进行序列化,再 zlib 压缩,最后 base64(替换了某些字符,具体哪些看代码)。

需要注意的是,加密曲线使用的是 secp256k1, 有些系统的 openssl 是不支持这个曲线的。查看系统所支持的所有曲线,可参考 list_all_curves, 这个方法会打印出所有支持的曲线。如果你的服务器恰好支持这个曲线,那经过上面的过程就可以正常使用了。

如果你的服务器不支持 secp256k1,可以使用 python ecdsa 。python ecdsa 开发库 下载地址

使用 pip 安装:pip install ecdsa

由于 python ecdsa 这个开发库仅支持 ec 格式的私钥,从腾讯云下载的私钥格式是 pk #8 的格式,需要使用 openssl 命令进行转换。转换命令如下:openssl ec -outform PEM -inform PEM -in private.pem -out private_ec.pem

-in 后面的传入下载的私钥 -out 后面是转换后的私钥文件

最终实现代码:#! /usr/bin/python# coding:utf-8import OpenSSL, base64, zlib, json, time, hashlib

from ecdsa import SigningKey,util# 这里请填写应用自己的私钥ecdsa_pri_key = """

请填上应用自己的私钥

"""def base64_encode_url(data):

base64_data = base64.b64encode(data)

base64_data = base64_data.replace('+', '*')

base64_data = base64_data.replace('/', '-')

base64_data = base64_data.replace('=', '_')    return base64_datadef base64_decode_url(base64_data):

base64_data = base64_data.replace('*', '+')

base64_data = base64_data.replace('-', '/')

base64_data = base64_data.replace('_', '=')

raw_data = base64.b64decode(base64_data)    return raw_dataclass TLSSigAPI:

""""""

__acctype = 0

__identifier = ""

__appid3rd = ""

__sdkappid = 0

__version = 20151204

__expire = 3600*24*30       # 默认一个月,需要调整请自行修改

__pri_key = ""

__pub_key = ""

_err_msg = "ok"

def __get_pri_key(self):        return self.__pri_key_loaded    def __init__(self, sdkappid, pri_key):        self.__sdkappid = sdkappid        self.__pri_key = pri_key        self.__pri_key_loaded = SigningKey.from_pem(self.__pri_key)    def __create_dict(self):

m = {}

m["TLS.account_type"] = "%d" % self.__acctype

m["TLS.identifier"] = "%s" % self.__identifier

m["TLS.appid_at_3rd"] = "%s" % self.__appid3rd

m["TLS.sdk_appid"] = "%d" % self.__sdkappid

m["TLS.expire_after"] = "%d" % self.__expire

m["TLS.version"] = "%d" % self.__version

m["TLS.time"] = "%d" % time.time()        return m    def __encode_to_fix_str(self, m):

fix_str = "TLS.appid_at_3rd:"+m["TLS.appid_at_3rd"]+"\n" \

+"TLS.account_type:"+m["TLS.account_type"]+"\n" \

+"TLS.identifier:"+m["TLS.identifier"]+"\n" \

+"TLS.sdk_appid:"+m["TLS.sdk_appid"]+"\n" \

+"TLS.time:"+m["TLS.time"]+"\n" \

+"TLS.expire_after:"+m["TLS.expire_after"]+"\n"

return fix_str    def tls_gen_sig(self, identifier):        self.__identifier = identifier

m = self.__create_dict()

fix_str = self.__encode_to_fix_str(m)

pk_loaded = self.__get_pri_key()

sig_field = pk_loaded.sign(fix_str, hashfunc=hashlib.sha256, sigencode=util.sigencode_der)

sig_field_base64 = base64.b64encode(sig_field)

m["TLS.sig"] = sig_field_base64

json_str = json.dumps(m)

sig_cmpressed = zlib.compress(json_str)

base64_sig = base64_encode_url(sig_cmpressed)        return base64_sig

def main():

api = TLSSigAPI(1400001052, ecdsa_pri_key)

sig = api.tls_gen_sig("xiaojun")

print sigif __name__ == "__main__":

main()

作者:莫17

链接:https://www.jianshu.com/p/f7bf639a554e

腾讯云 python接口_Python 服务端集成 腾讯云 IM 服务相关推荐

  1. python 服务端渲染_客户端渲染与服务端渲染

    后端渲染 服务器直接生成HTML文档并返回给浏览器,但页面交互能力有限.适用于任何后端语言:PHP.Java.Python.GO等. 客户端渲染(CSR) 页面初始加载的HTML文档中无内容,需要下载 ...

  2. 使用极光推送实现分组发送和服务端集成

    推送功能在手机应用开发中越来越重要,几乎成为所有App必备的功能,由于Android本身没有消息推送机制,通常采用的是基于XMPP协议的推送,但这种开发很麻烦,因此在市场上应运而生了提供消息推送服务的 ...

  3. t3畅捷通显示不能登陆服务器,用友T3提示不能登录到服务器:解析服务端数据出现错误,可能服务端是8.13的先前版本?...

    文章摘要:问题现象:第1种情况:登录的时候就直接提示:不能登录到服务器:pc-pcfailed:解析服务端数据出现错误,可能服务端是8.13的先前版本,第二种情况:登录用友T3软件后,点击模块提示:检 ...

  4. 用友 无法正确解析服务器,不能登录到服务器,解析服务端数据出现错误,可能服务端是8.13的先前版本?...

    摘要: 刚刚安装的用友T3财务软件,登录后,基础设置操作正常,但登录总账模块时提示:不能登录到服务器(NHAWM),请检查服务器配置:FAILED:解析服务端数据出现错误,可能服务端是8.13的先前版 ...

  5. 用友 无法正确解析服务器,用友T3提示不能登录到服务器:解析服务端数据出现错误,可能服务端是8.13的先前版本?...

    文章摘要:问题现象:第1种情况:登录的时候就直接提示:不能登录到服务器:pc-pcfailed:解析服务端数据出现错误,可能服务端是8.13的先前版本,第二种情况:登录用友T3软件后,点击模块提示:检 ...

  6. java服务端集成信鸽推送

    java服务端集成信鸽推送 最近项目需要集成推送功能,突发奇想的选了信鸽推送(可能是最近一直在用阿里的东西),没想到这坑不是一般的多,而且关于详细的集成案例,度娘上真是没一个能入眼的.算了,别的不多说 ...

  7. 哪些深度相机有python接口_python 从深度相机realsense生成pcl点云

    简单说下步骤: 一.通过realsense取得深度信息和彩色信息 二.获取坐标和色彩信息 三.通过pcl可视化点云 一.通过realsense取得深度信息和彩色信息 ubuntu下intel real ...

  8. c++调用python接口_Python调用有道智云文本翻译API接口实现“智能”伪原创

    >> 开始伪原创中..\")"],[20,"\n","24:\"OL7j\"|36:131"],[20,&q ...

  9. python自动化测试视频百度云-Python接口自动化测试 PDF 超清版

    给大家带来的一篇关于Python自动化相关的电子书资源,介绍了关于Python.接口自动化.测试方面的内容,本书是由电子工业出版社出版,格式为PDF,资源大小61.2 MB,王浩然编写,目前豆瓣.亚马 ...

  10. python自动化测试视频百度云-python接口自动化测试视频教程全集

    python接口自动化测试视频教程全集 下载地址:https://k.weidian.com/Pfm=DyuI 课程内容: 第一章:接口测试基础 1-1 接口自动化课程简介 1-2 接口测试课程大纲 ...

最新文章

  1. Java 代码的基本知识
  2. C++primer第十一章 关联容器 11.3关联容器操作 11.4 无序容器
  3. extract()函数:用于从一个date或者interval类型中截取到特定的部分
  4. hibernate annotations @Entity hql XX not mapped
  5. kernel panic 分析解决方法
  6. java药品管理系统源代码,基于jsp的药品管理系统-JavaEE实现药品管理系统 - java项目源码...
  7. 杭州吃喝玩乐便民大全
  8. 这么多技术我该怎么学 杨中科
  9. mysql的pom文件在哪_Maven中pom文件详解
  10. 等级保护--云计算安全扩展要求
  11. desc和asc用法
  12. 多模态生物特征识别文章略读
  13. java获取网页编码_java根据URL获取网页编码
  14. 点到平面的距离(最短距离)
  15. python字符串equals方法_equals方法和 == 的使用
  16. wazuh官方安装指南(中文译版本)
  17. 音诺恒科技多核验合一“数字电子哨兵”对接全国健康码精准核验
  18. 旧电脑安装黑群晖(5.1-5022)
  19. 淘宝助理的sqlite3数据库解密
  20. 国考省考行测:资料分析:增量减量计算公式,百分数化分数

热门文章

  1. linux驱动开发:mma7660 sensor的配置
  2. 对于离散行业如何选型MES系统,你知道吗?
  3. 读书百客:《渔家傲·天接云涛连晓雾》评赏
  4. 继电器----D型触发器,边沿触发器,累加器
  5. 语音芯片ic分类以及sop8的otp语音芯片对比 选型
  6. sql语句动态拼接多个查询条件查询数据库
  7. 一条用来表示“思路非常乱。。。”的博客
  8. 【西窗】2019杭州交通限行规定(最新地图详情)
  9. 公共DNS递归服务器(转发)
  10. JAVA_判断日期是否为工作日(排除节假日和调整周末上班)