签名验签自助排查
簽名驗簽自助排查?
支付寶開放平臺SDK封裝了簽名和驗簽過程,只需配置賬號及密鑰參數,強烈建議使用。?
SDK下載地址?
TIPS:文中代碼部分以JAVA語言演示,其他語言請參考各自SDK。?
使用開放平臺SDK接入?
如果使用了開放平臺SDK,簽名驗簽問題通常是因為密鑰配置錯誤導致。?
配置代碼示例,問題描述中會以示例中的變量名為例:?
AlipayClient alipayClient = new DefaultAlipayClient(gateway,app_id,private_key,"json",charset,alipay_public_key,sign_type);?
簽名問題?
Q:SDK拋出異常:“com.alipay.api.AlipayApiException: RSA私鑰格式不正確,請檢查是否正確配置了PKCS8格式的私鑰”。?
A:代碼中私鑰(private_key)格式錯誤導致。1>.檢查格式是否正確。Java需使用PKCS8格式,其他語言使用PKCS1格式。?
2>.檢查私鑰是否一行。?
Q:請求時,SDK拋出異常:“java.lang.NullPointerException: privateKey should not be NULL!”。?
A:代碼中私鑰(private_key)參數未賦值導致。請把商戶應用私鑰賦值給該參數。?
Q:請求時,SDK拋出異常:“java.security.NoSuchAlgorithmException: MD5 KeyFactory not available”。?
A:代碼中簽名類型(sign_type)設置錯誤導致。開放平臺接口需設置成RSA。?
Q:請求時,支付寶返回報錯信息:“{"code":"40003","msg":"Insufficient Conditions","sub_code":"isv.missing-signature-config","sub_msg":"驗簽出錯, 未配置對應簽名算法的公鑰或者證書"}”?
A:開放平臺未配置商戶公鑰導致。請登錄開放平臺,上傳公鑰。教程?
Q:請求時,支付寶返回報錯信息:“{"code":"40002","msg":"Invalid Arguments","sub_code":"isv.invalid-signature","sub_msg":"無效簽名"}”?
A:簽名校驗失敗。1>.檢查網關地址(gateway)是生產環境還是沙箱環境,必須使用與之匹配的應用id(app_id)與私鑰(private_key)
2>.檢查編碼類型(charset)是否正確。?
3>.檢查私鑰(private_key)與開放平臺上傳的應用公鑰是否匹配。?
4>.檢查簽名類型(sign_type)值是否正確。如果未傳入sign_type參數,默認為RSA類型。?
驗簽問題?
Q:SDK拋出異常:“java.lang.NullPointerException: alipayPublicKey should not be NULL!”。?
A:代碼中支付寶公鑰(alipay_public_key)參數未賦值導致。請把支付寶公鑰賦值給該參數。教程?
Q:SDK拋出異常:“java.security.InvalidKeyException”?
A:代碼中支付寶公鑰(alipay_public_key)參數內容錯誤導致。請核對。?
Q:SDK拋出異常:“com.alipay.api.AlipayApiException: sign check fail: check Sign and Data Fail!”?
A:支付寶返回內容驗簽失敗。1>.檢查網關地址(gateway)是生產環境還是沙箱環境,必須使用與之匹配的應用id(app_id)與支付寶公鑰(alipay_public_key)?
2>.檢查編碼類型(charset)是否正確。?
3>.檢查代碼中支付寶公鑰(alipay_public_key)參數與開放平臺上獲取的支付寶公鑰是否一致。?
Q:SDK拋出異常:“Caused by: java.security.SignatureException: Signature length not correct: got 256 but was expecting 128”?
A:支付寶公鑰(alipay_public_key)與簽名類型(sign_type)不匹配。Sign_type設置為RSA2,alipay_public_key需使用對應的支付寶公鑰,不能使用開放平臺RSA類型下的支付寶公鑰。?
Q:SDK拋出異常:“Caused by: java.security.SignatureException: Signature length not correct: got 128 but was expecting 256”?
A:支付寶公鑰(alipay_public_key)與簽名類型(sign_type)不匹配。Sign_type設置了RSA,alipay_public_key需使用對應的支付寶公鑰,不能使用開放平臺RSA2類型下的支付寶公鑰。?
Q:AlipaySignature.rsaCheckV1()方法返回false?
A:驗簽失敗,方法同上。?
TIPS:開放平臺SDK提供了AlipaySignature.rsaCheckV1()與AlipaySignature.rsaCheckV2()兩個版本。V1驗簽時會剔除sign_type參數,V2會保留sign_type參數。V2僅適用于生活號接口
。
總結
- 上一篇: WebSocket-nodejs实现
- 下一篇: docker中centos遇到sudo: