JAVA WeChat 公開アカウントの開発時に TOKEN 検証が失敗した場合はどうすればよいですか?
JAVA WeChat パブリック アカウント開発のトークン検証エラーの解決策:
WeChat パブリック プラットフォーム サーバーを構成するとき、トークンを導入する必要がありますが、それを送信するときにWeChat バックエンドがコード内の検証トークン コードを検出しなかったため、トークンの検証が失敗したことを示すプロンプトが表示されます。その後、公式ドキュメントに従ってトークンを検証し、検証後に結果を WeChat パブリック プラットフォームに返す必要があります。
検証コードは:
public class SignUtil { private static String token = "WnbVm6GTQj4BPmLliSday4K";//这里是自定义的token,需和你提交的token一致 /** * 校验签名 * * @param signature * 签名 * @param timestamp * 时间戳 * @param nonce * 随机数 * @return 布尔值 */ public static boolean checkSignature(String signature, String timestamp, String nonce) { String checktext = null; if (null != signature) { // 对ToKen,timestamp,nonce 按字典排序 String[] paramArr = new String[] { token, timestamp, nonce }; Arrays.sort(paramArr); try { MessageDigest md = MessageDigest.getInstance("SHA-1"); // 对接后的字符串进行sha1加密 byte[] digest = md.digest(content.toString().getBytes()); checktext = byteToStr(digest); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } } // 将加密后的字符串与signature进行对比 return checktext != null ? checktext.equals(signature.toUpperCase()) : false; } /** * 将字节数组转化为16进制字符串 * * @param byteArrays * 字符数组 * @return 字符串 */ private static String byteToStr(byte[] byteArrays) { String str = ""; for (int i = 0; i < byteArrays.length; i++) { str += byteToHexStr(byteArrays[i]); } return str; } /** * 将字节转化为十六进制字符串 * * @param myByte * 字节 * @return 字符串 */ private static String byteToHexStr(byte myByte) { char[] Digit = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; char[] tampArr = new char[2]; tampArr[0] = Digit[(myByte >>> 4) & 0X0F]; tampArr[1] = Digit[myByte & 0X0F]; String str = new String(tampArr); return str; } }
送信時、パブリック プラットフォームはあなたのアドレスを要求し、バックグラウンドで検証したかどうかを確認します。検証部分:
if (StringUtils.isNotBlank(request.getParameter("signature"))) { String signature = request.getParameter("signature"); String timestamp = request.getParameter("timestamp"); String nonce = request.getParameter("nonce"); String echostr = request.getParameter("echostr"); LOGGER.info("signature[{}], timestamp[{}], nonce[{}], echostr[{}]", signature, timestamp, nonce, echostr); if (SignUtil.checkSignature(signature, timestamp, nonce)) { LOGGER.info("数据源为微信后台,将echostr[{}]返回!", echostr); response.getOutputStream().println(echostr); } }
推奨チュートリアル: 「JAVA ビデオ チュートリアル 」
以上がJAVA WeChat パブリック アカウント開発トークンの検証に失敗した場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。