python2.7下面字节数组(ByteArray)和16进制字符串(HexString)转化
由于是python2.7
严谨起见,文中不使用字符串的说法,下面只使用str或者unicode的说法
之所以有这个需要,是因为:
Hmac-sha1加密在网上计算的结果是HexString,也就是16进制字符串
而在python中的计算结果是ByteArray,两者结果不同,于是就萌生了两者如何转化的疑问.
由于python2.7中没有Bytes
py2没有bytes的概念 所以把字节数组当成str输出了
下面是互相转化的方法:
# coding: utf-8 #在线计算链接http://tool.oschina.net/encrypt?type=2 #用来加密的字符串:csdmniojfw98nvdico #需要输入的秘钥:214fdsf23dc import hmac import hashlib import base64 import hashlib def hmac_sha1(app_secret,base_result): result=hmac.new(app_secret,base_result, hashlib.sha1).digest() l=["{:02X}".format(ord(i)) for i in result] s="".join(l) print"以上是从python结果转化为在线计算结果,也就是从字节数组转化为16进制数组" news=bytearray.fromhex(s) print"以上是从在线计算结果转化为python结果,也就是从16进制数组转化为字节数组" print "s=",s print "news=",news return result if __name__ == "__main__": app_secret="214fdsf23dc" base_result="csdmniojfw98nvdico" result=hmac_sha1(app_secret,base_result) print "result=",result
声明:该文观点仅代表作者本人,入门客AI创业平台信息发布平台仅提供信息存储空间服务,如有疑问请联系rumenke@qq.com。
- 上一篇: 如何运行.ipynb文件
- 下一篇:没有了