在使用Authorize.Net中的Webhook时,如果始终无法通过身份验证,可以尝试以下解决方法:
确保使用的API密钥和签名密钥是正确的。可以在Authorize.Net的开发者门户中获取这些密钥。确保将正确的密钥用于Webhook的身份验证。
确保在接收Webhook请求时,正确地验证签名。可以使用以下代码示例来验证签名:
import hmac
import hashlib
import base64
# 接收到的Webhook请求数据
webhook_data = ...
# 从Authorize.Net开发者门户中获取的签名密钥
signature_key = 'your_signature_key'
# 从请求头中获取签名和时间戳
signature = request.headers.get('X-Anet-Signature')
timestamp = request.headers.get('X-Anet-Timestamp')
# 构造用于验证的签名字符串
signature_string = timestamp + '^' + webhook_data
# 计算签名
hashed_signature = hmac.new(signature_key.encode(), msg=signature_string.encode(), digestmod=hashlib.sha512).digest()
computed_signature = base64.b64encode(hashed_signature).decode()
# 验证签名是否匹配
if signature == computed_signature:
# 签名验证通过
# 在此处处理Webhook请求的逻辑
else:
# 签名验证失败
# 在此处处理签名验证失败的逻辑
确保在代码中将your_signature_key
替换为从Authorize.Net开发者门户中获取的实际签名密钥。
通过以上解决方法,您应该能够正确验证Authorize.Net中的Webhook请求的身份。