java后台开发微信公众号笔记

开发环境的搭建--开通隧道

1、官网看介绍,下载客户端:https://www.ngrok.cc/

2、注册账号,申请免费渠道:https://www.ngrok.cc/login

3、用渠道ID,启动,映射本地的8080端口

package com.aja.test_wx.controller;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;

import java.io.ByteArrayInputStream;
import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

@Controller
public class connect {

    private final String TOKEN = "aja";

    /**
     * 认证
     * @param signature
     * @param timestamp
     * @param nonce
     * @param echostr
     * @return
     * @throws NoSuchAlgorithmException
     */
    @GetMapping(value = "/wx/connect")
    @ResponseBody
    public String connect(String signature, String timestamp, String nonce, String echostr) throws NoSuchAlgorithmException {
        System.out.println(signature+"|"+timestamp+"|"+nonce+"|"+echostr);
//        1)将token、timestamp、nonce三个参数进行字典序排序
        String[] strs = {TOKEN, timestamp, nonce};
        Arrays.sort(strs);
//        2)将三个参数字符串拼接成一个字符串进行sha1加密
        String s = strs[0] + strs[1] + strs[2];
        String s1 = sha1(s);
//        3)开发者获得加密后的字符串可与signature对比,标识该请求来源于微信
        if (s1.equals(signature)){
            //若确认此次GET请求来自微信服务器,请原样返回echostr参数内容,则接入生效,成为开发者成功,否则接入失败。
            System.out.println(s1);
            System.out.println(signature);
            return echostr;
        }else {
            return "false";
        }
    }

    /**
     * 接受消息
     * @param xml
     * @return
     * @throws DocumentException
     */
    @PostMapping(value = "/wx/connect")
    @ResponseBody
    public String message(@RequestBody String xml) throws DocumentException {
        Map<String, String> map = new HashMap<>();
        SAXReader saxReader = new SAXReader();
        //读入文件
        ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(xml.getBytes(StandardCharsets.UTF_8));
        Document read = saxReader.read(byteArrayInputStream);
        //获得根节点
        Element rootElement = read.getRootElement();
        //获取根节点下所有子节点
        List<Element> elements = rootElement.elements();
        for (Element e:elements)
            map.put(e.getName(),e.getStringValue());
        System.out.println(map);
        return "";
    }

    /**
     * 进行sha1加密
     * @param s
     * @return
     */
    private String sha1(String s) throws NoSuchAlgorithmException {
        //获取一个加密对象
        MessageDigest sha1 = MessageDigest.getInstance("sha1");
        //加密
        byte[] digest = sha1.digest(s.getBytes());
        char[] chars = new char[]{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
        StringBuilder stringBuilder = new StringBuilder();
        //处理加密结果
        for (byte b:digest){
            stringBuilder.append(chars[(b>>4)&15]);
            stringBuilder.append(chars[b&15]);
        }
        return stringBuilder.toString();
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值