03节-微信公众号验证

03节-微信公众号验证

目录

1.创建Springboot web项目

2.写验证程序


1.创建Springboot web项目

  • 新建项目

 

  • 进行参数设置

  • 选择springboot嵌入的内容

 

  • 搭建好了之后如果有创建Servlet需要进行配置

使用Servlet必须要配置ServletComponentScan,basePackages里面配置的是Servlet的路径

 

2.写验证程序

 

  • 首先是URL的填写

我这上面接收的是/wx

 

所以我在微信公众号配置的就是ngrok的网址

http://missgxl.free.idcfengye.com + /wx/

  • 写验证信息
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//        System.out.println("get");
        //微信平台接入验证
        /**
         *
         * signature   微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。
         * timestamp   时间戳
         * nonce   随机数
         * echostr 随机字符串
         */
        String signature = (String) req.getParameter("signature");
        String timestamp = (String) req.getParameter("timestamp");
        String nonce =  (String) req.getParameter("nonce");
        String echostr =  (String) req.getParameter("echostr");

        // 能获取到了配置信息
        // 按照规则进行校验
        if (WxutilService.check(timestamp,nonce,signature)){
            System.out.println("接入成功");
            PrintWriter out = resp.getWriter();
            //原样返回echostr完成接入校验
            out.write(echostr);
            out.flush();
            out.close();
        }else {
            System.out.println("接入失败");
        }

    }
  • 信息验证流程
private static final String TOKEN = "xx"; //在测试公众号上填写的Token

public static boolean check(String timestamp, String nonce, String signature)  {
    // 1)将token、timestamp、nonce三个参数进行字典序排序
    String [] strs = new String[]{TOKEN,timestamp,nonce};
    Arrays.sort(strs);
    // 2)将三个参数字符串拼接成一个字符串进行sha1加密
    String str = strs[0]+strs[1]+strs[2];

    String mysig = sha1(str);
    System.out.println(mysig);
    System.out.println(signature);

    // 3)开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
    return mysig.equalsIgnoreCase(signature);
}
  // 进行sha1加密
    private static String sha1(String str)  {
        try {
            //获取加密对象
            MessageDigest md = MessageDigest.getInstance("sha1");
            //进行加密操作
            byte[] digest =md.digest(str.getBytes());
            char[] chars = {'0','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'};
            StringBuilder sb = new StringBuilder();
            // 处理加密结果
            // 处理详解 获取的byte是8位, 8位带代表两个字节所以有高4位和低四位分开处理
            // 四位二进制代表 0-15
            for (byte b : digest){
                // 首先进行第四位的处理
                sb.append(chars[(b>>4)&15]);
                // 然后进行高四位的处理
                sb.append(chars[(b)&15]);
            }
            return sb.toString();
        }catch (Exception e){
        }
        return "0";
    }
  • 验证通过微信就能配置上

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值