前言

一般公司对外的接口都会用到sign签名,对不同的客户提供不同的apikey ,这样可以提高接口请求的安全性,避免被人抓包后乱请求。

sign签名是一种很常见的方式

sign签名

签名参数sign生成的方法

  • 第1步: 将所有参数(注意是所有参数),除去sign本身,以及值是空的参数,按参数名字母升序排序。
  • 第2步: 然后把排序后的参数按参数1值1参数2值2…参数n值n(这里的参数和值必须是传输参数的原始值,不能是经过处理的,如不能将"转成”后再拼接)的方式拼接成一个字符串。
  • 第3步: 把分配给接入方的验证密钥key拼接在第2步得到的字符串key。
  • 第2步: 在上一步得到的字符串后面加上验证密钥key(这里的密钥key是接口提供方分配给接口接入方的),然后计算md5值,得到32位字符串,然后转成大写.
  • 第4步: 计算第3步字符串转小写后得到的md5值(32位),得到的字符串作为sign的值。

假设传输的数据是http://www.xxx.com/interface.aspx?sign=sign_value&p2=v2&p1=v1&method=cancel&p3=&pn=vn

(实际情况最好是通过post方式发送),

其中sign参数对应的sign_value就是签名的值。

第一步,拼接字符串,首先去除sign参数本身,然后去除值是空的参数p3,剩下p2=v2&p1=v1&method=cancel&pn=vn,

然后按参数名字符升序排序,method=cancel&p1=v1&p2=v2&pn=vn.

第二步,然后做参数名和值的拼接,最后得到methodcancelp1v1p2v2pnvn

第三步,在上面拼接得到的字符串后加上验证密钥key,我们假设是abc,得到新的字符串methodcancelp1v1p2v2pnvnabc

第四步,然后将这个字符串换为小写进行md5计算,假设得到的是abcdef,这个值即为sign签名值。

注意,计算md5之前请确保接口与接入方的字符串编码一致,如统一使用utf-8编码或者GBK编码,如果编码方式不一致则计算出来的签名会校验失败。

python实现sign签名

我们假设提供的apikey为12345678,请求的body参数为

body = {
"username": "test",
"password": "123456",
"mail": "",
"sign": "签名后的值"
}

使用python实现签名

import hashlib

apikey = "12345678"  # 验证密钥,由开发提供

body = {
"username": "test",
"password": "123456",
"mail": ""
} # 列表生成式,生成key=value格式
a = ["".join(i) for i in body.items() if i[1] and i[0] != "sign"]
print(a)
# 参数名ASCII码从小到大排序
strA = "".join(sorted(a))
print(strA) # 在strA后面拼接上apiKey得到striSignTemp字符串
striSignTemp = strA+apikey # 将strSignTemp字符串转换为小写字符串后进行MD5运算 # MD5加密
def jiamimd5(src):
m = hashlib.md5()
m.update(src.encode('UTF-8'))
return m.hexdigest() sign = jiamimd5(striSignTemp.lower())
print(sign) # 得到sign签名后新的body值
body["sign"] = sign
print(body)

运行结果

['usernametest', 'password123456']
password123456usernametest
1aca01806e93bb408041965a817666af
{'username': 'test', 'password': '123456', 'mail': '', 'sign': '1aca01806e93bb408041965a817666af'}

签名函数

把上面记流水账的代码,写成一个函数,方便调用

import hashlib

def sign_body(body, apikey="12345678"):
'''请求body sign签名'''
# 列表生成式,生成key=value格式
a = ["".join(i) for i in body.items() if i[1] and i[0] != "sign"]
# print(a)
# 参数名ASCII码从小到大排序
strA = "".join(sorted(a))
# print(strA) # 在strA后面拼接上apiKey得到striSignTemp字符串
striSignTemp = strA+apikey # 将strSignTemp字符串转换为小写字符串后进行MD5运算 # MD5加密
def jiamimd5(src):
m = hashlib.md5()
m.update(src.encode('UTF-8'))
return m.hexdigest()
sign = jiamimd5(striSignTemp.lower())
# print(sign) # 得到sign签名后新的body值
body["sign"] = sign
# print(body) return body if __name__ == '__main__':
apikey = "12345678" # 验证密钥,由开发提供 body = {
"username": "test",
"password": "123456",
"mail": "",
"sign": ""
}
print(sign_body(body, apikey="12345678"))

最新文章

  1. Spark的Straggler深入学习(2):思考Block和Partition的划分问题——以论文为参考
  2. HTTP网页错误代码大全带解释
  3. 服务器调用JS
  4. Oracle体系结构图
  5. vmware9.0 安装ios10.8应该注意的地方
  6. vs2013 中已经添加了引用,编译还是提示没有添加引用
  7. ThinkPHP3.2.3版本框架could not find driver错误
  8. 黄聪:基于Asp.net的CMS系统We7架设实验(环境WIN7,SQL2005,.NET3.5)(初学者参考贴)
  9. enote笔记语言(3)(ver0.2)
  10. 免费搭建wordpress博客有感
  11. Vue多元素过渡
  12. Java课程设计-计算器 丁树乐(201521123024)
  13. readfile & file_get_contents异同
  14. UVALive3882-And Then There Was One-约瑟夫问题-递推
  15. 第五节 matplotlib库
  16. tomcat之虚拟目录
  17. [转]vue跨域解决方法
  18. 串口发送端verilog代码分析
  19. 解决Ubuntu无法进行SSH连接的问题(以及如何使用SSH)
  20. html5 class

热门文章

  1. Spring Transaction 使用入门 (转)
  2. python3.5以上版本,typing模块提高代码健壮性
  3. elasticsearch 常用命令 一直红色 重启不稳定 不停的宕机
  4. mysql创建存储过程动态SQL语句
  5. .NET配置引用程序集的路径(分离exe和dll)
  6. javascript 函数的暂停和恢复
  7. [转帖]Kubernetes的部署策略
  8. Django 模板语言 变量名称
  9. 『正睿OI 2019SC Day1』
  10. vue日历/日程提醒/html5本地缓存