>  기사  >  Java  >  JAVA WeChat 공개 계정 개발 TOKEN이 검증에 실패하면 어떻게 해야 합니까?

JAVA WeChat 공개 계정 개발 TOKEN이 검증에 실패하면 어떻게 해야 합니까?

coldplay.xixi
coldplay.xixi원래의
2020-06-13 09:37:463729검색

JAVA WeChat 공개 계정 개발 TOKEN이 검증에 실패하면 어떻게 해야 합니까?

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 = { &#39;0&#39;, &#39;1&#39;, &#39;2&#39;, &#39;3&#39;, &#39;4&#39;, &#39;5&#39;, &#39;6&#39;, &#39;7&#39;, &#39;8&#39;, &#39;9&#39;, &#39;A&#39;, &#39;B&#39;, &#39;C&#39;, &#39;D&#39;, &#39;E&#39;, &#39;F&#39; };
        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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.