JAVA WeChat 공용 계정 개발 TOKEN이 검증에 실패하면 어떻게 해야 하나요?
JAVA WeChat 공개 계정 개발 시 TOKEN 확인 실패에 대한 해결 방법:
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 Video Tutorial"
위 내용은 JAVA WeChat 공개 계정 개발 TOKEN이 검증에 실패하면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!