- A+
最近做的项目,需要接入腾讯云 IM,翻看了一下文档,iOS、Android 以及 Web 端基本上都有 SDK 可以集成。我使用的服务端是用 Python 写的,腾讯 IM 暂时还没有 Python 的官方文档。但是在腾讯云的官方论坛上找到了解决方法。
闲来没事写写文章,就是个人兴趣爱好,希望跟读者君共同学习讨论。分享自己的Python学习交流群:643692991可以加入,里面还有我上传了一些资料,包括2017最新的python企业案例学习资料和零基础入门教程,希望对各位有帮助。程序还是需要多写,多思考多变化。代码多敲就熟练了,不管天赋怎样,勤能补拙嘛。
服务端最基本的一个需求是:使用接入用户的 identifier 和应用申请的腾讯云 appid、私钥等信息,通过指定算法,生成用户用来登录腾讯云 IM 的 usersig。
源代码:
#! /usr/bin/python
过程:
-
将用户的信息组装成一个字符串(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