微信公众号服务器配置------token验证(java版)

本文详细介绍了一个简单的微信公众号接入流程,包括设置Token、实现CoreServlet处理请求、使用SignUtil进行签名验证。通过三个核心文件Constant、CoreServlet和SignUtil,演示了如何在服务器上部署并验证微信公众号。
部署运行你感兴趣的模型镜像

做一个简单的小项目,放到服务器tomcat的webapps下,启动项目,访问成功,即可保存服务器的配置

需要三个文件:

1、Constant

package com.xkx.constants;

public class Constant {
    // ��ӿ�������Ϣ�е�TokenҪһ��
    public final static String TOKEN = "xxxxxxx你的token值";
}

 

2、CoreServlet

import java.io.PrintWriter;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.xkx.util.SignUtil;

/**
 * ������������
 * 
 */
@SuppressWarnings("serial")
public class CoreServlet extends HttpServlet {


    /**
     * ȷ����������΢�ŷ�����
     */
    public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
        // ΢�ż���ǩ��
        System.out.println("---验证开始---");
        String signature = request.getParameter("signature");
        System.out.println("--1--"+signature);
        // ʱ���
        String timestamp = request.getParameter("timestamp");
        System.out.println("--2--"+timestamp);
        // �����
        String nonce = request.getParameter("nonce");
        System.out.println("--3--"+nonce);
        // ����ַ�
        String echostr = request.getParameter("echostr");
        System.out.println("--4--"+echostr);

        PrintWriter out = response.getWriter();
        // ͨ�����signature���������У�飬��У��ɹ���ԭ���echostr����ʾ����ɹ����������ʧ��
        if (SignUtil.checkSignature(signature, timestamp, nonce)) {
            System.out.println("--9--");
            out.print(echostr);
            System.out.println("--10--"+echostr);
            System.out.println("--验证结束--");
        }
        out.close();
        out = null;
    }

    /**
     * ����΢�ŷ�������������Ϣ
     */
    public void doPost(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {
    }

}

3、SignUtil

package com.xkx.util;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;

import com.xkx.constants.Constant;


/**
 * ����У�鹤����
 * 
 */
public class SignUtil {

    /**
     * ��֤ǩ��
     * 
     * @param signature
     * @param timestamp
     * @param nonce
     * @return
     */
    public static boolean checkSignature(String signature, String timestamp,
            String nonce) {
        String[] arr = new String[] { Constant.TOKEN, timestamp, nonce };
        System.out.println("--5--"+arr);
        // ��token��timestamp��nonce�����������ֵ�������
        Arrays.sort(arr);
        StringBuilder content = new StringBuilder();
        for (int i = 0; i < arr.length; i++) {
            content.append(arr[i]);
            System.out.println("--6--"+arr[i]);
        }
        MessageDigest md = null;
        String tmpStr = null;

        try {
            md = MessageDigest.getInstance("SHA-1");
            // ����������ַ�ƴ�ӳ�һ���ַ����sha1����
            byte[] digest = md.digest(content.toString().getBytes());
            System.out.println("--7--"+digest);
            tmpStr = byteToStr(digest);
            System.out.println("--8--"+tmpStr);
        } catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }

        content = null;
        // ��sha1���ܺ���ַ����signature�Աȣ���ʶ��������Դ��΢��
        return tmpStr != null ? tmpStr.equals(signature.toUpperCase()) : false;
    }

    /**
     * ���ֽ�����ת��Ϊʮ������ַ�
     * 
     * @param byteArray
     * @return
     */
    private static String byteToStr(byte[] byteArray) {
        String strDigest = "";
        for (int i = 0; i < byteArray.length; i++) {
            strDigest += byteToHexStr(byteArray[i]);
        }
        return strDigest;
    }

    /**
     * ���ֽ�ת��Ϊʮ������ַ�
     * 
     * @param mByte
     * @return
     */
    private static String byteToHexStr(byte mByte) {
        char[] Digit = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A',
                'B', 'C', 'D', 'E', 'F' };
        char[] tempArr = new char[2];
        tempArr[0] = Digit[(mByte >>> 4) & 0X0F];
        tempArr[1] = Digit[mByte & 0X0F];

        String s = new String(tempArr);
        return s;
    }
}

 

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

根据引用\[1\]和引用\[2\]的描述,您在微信公众号开发中遇到了服务器配置token验证失败的问题。根据引用\[3\]中的代码,您使用了一个@GetMapping注解的方法来处理微信服务器发起的验证请求。在这个方法中,您通过调用iService.checkSignature方法来验证signature、timestamp、nonce和echostr参数的正确性。如果验证通过,就返回echostr的值。 根据您的描述,您的服务器接收到了数据并且验证通过,也成功地返回了echostr的值。然而,您仍然遇到了"token校验失败"的问题。 可能的原因是您在验证token时出现了一些问题。请确保您在验证token时使用了正确的token值,并且在验证过程中没有出现任何错误。您可以检查一下您的token值是否正确,并且确认您的验证逻辑是否正确。 另外,您还可以检查一下您的服务器配置是否正确。请确保您在微信公众平台上正确填写了服务器配置的相关信息,并且将token值与您的代码中的token值保持一致。 如果您仍然无法解决问题,建议您查看微信公众平台的文档或者寻求相关的开发支持,以获取更详细的帮助和指导。 #### 引用[.reference_title] - *1* *3* [微信公众号服务器配置token验证失败原因](https://blog.youkuaiyun.com/qq_40985294/article/details/105257416)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [微信公众平台服务器配置token验证失败](https://blog.youkuaiyun.com/gaozhilu88520/article/details/88552415)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值