为了确保 开放接口 返回用户数据的安全性,微信会对明文数据进行签名。开发者可以根据业务需要对数据包进行签名校验,确保数据的完整性。
如wx.getuserinfo的数据校验:
接口返回的rawdata:
{
"nickname": "band",
"gender": 1,
"language": "zh_cn",
"city": "guangzhou",
"province": "guangdong",
"country": "cn",
"avatarurl": "http://wx.qlogo.cn/mmopen/vi_32/1vzvi39nwfq9xm4ltqpfrqj1xlgzxx3w7bqxkarol6503iuswjjn6nigbiaycajatpujxyzysrztuuicqim5ibxq/0"
}
用户的 session-key:
hyvfkgl5f5oqwjzzanzbbg==
所以,用于签名的字符串为:
{"nickname":"band","gender":1,"language":"zh_cn","city":"guangzhou","province":"guangdong","country":"cn","avatarurl":"http://wx.qlogo.cn/mmopen/vi_32/1vzvi39nwfq9xm4ltqpfrqj1xlgzxx3w7bqxkarol6503iuswjjn6nigbiaycajatpujxyzysrztuuicqim5ibxq/0"}hyvfkgl5f5oqwjzzanzbbg==
使用sha1得到的结果为
75e81ceda165f4ffa64f4068af58c64b8f54b88c
接口如果涉及敏感数据(如wx.getuserinfo
当中的 openid 和unionid ),接口的明文内容将不包含这些敏感数据。开发者如需要获取敏感数据,需要对接口返回的加密数据( encrypteddata )进行对称解密。解密算法如下:
微信官方提供了多种编程语言的示例代码(点击下载)。每种语言类型的接口名字均一致。调用方式可以参照示例。
另外,为了应用能校验数据的有效性,我们会在敏感数据加上数据水印( watermark )
watermark参数说明:
参数 | 类型 | 说明 |
---|---|---|
watermark | object | 数据水印 |
appid | string | 敏感数据归属appid,开发者可校验此参数与自身appid是否一致 |
timestamp | dateint | 敏感数据获取的时间戳, 开发者可以用于数据时效性校验 |
如接口wx.getuserinfo敏感数据当中的watermark:
{
"openid": "openid",
"nickname": "nickname",
"gender": gender,
"city": "city",
"province": "province",
"country": "country",
"avatarurl": "avatarurl",
"unionid": "unionid",
"watermark":
{
"appid":"appid",
"timestamp":timestamp
}
}
注:此前提供的加密数据(encryptdata)以及对应的加密算法将被弃用,请开发者不要再依赖旧逻辑。