Java搭建微信公众号的服务器配置(1)

import java.security.MessageDigest;

import java.security.NoSuchAlgorithmException;

import java.util.Arrays;

/**

* zh on 2020/5/18.

*/

public class SignUtil {

private static String token = “WeChatToken”;// 与微信公众号上的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);

//将排序后的结果拼成一个字符串

String content = paramArr[0].concat(paramArr[1]).concat(paramArr[2]);

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;

}

}

调用:

**

* zh on 2020/5/18.

*/

@RestController

@RequestMapping(path = “wxPublic”)

@CrossOrigin

/*

验证公众号token

*/

public class WxPublicController {

private static final Logger log = LoggerFactory.getLogger(TempMaterialController.class);

@GetMapping(value = “serial”)

public String checkSign(HttpServletRequest request, HttpServletResponse response) {

try {

String signature = request.getParameter(“signature”);

String timestamp = request.getParameter(“timestamp”);

String nonce = request.getParameter(“nonce”);

String echostr = request.getParameter(“echostr”);

log.info(“本身” + signature);

if (SignUtil.checkSignature(signature, timestamp, nonce)) {
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)

img

最后

由于篇幅限制,小编在此截出几张知识讲解的图解

P8级大佬整理在Github上45K+star手册,吃透消化,面试跳槽不心慌

P8级大佬整理在Github上45K+star手册,吃透消化,面试跳槽不心慌

P8级大佬整理在Github上45K+star手册,吃透消化,面试跳槽不心慌

P8级大佬整理在Github上45K+star手册,吃透消化,面试跳槽不心慌

P8级大佬整理在Github上45K+star手册,吃透消化,面试跳槽不心慌

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
R3-1712627212461)]

[外链图片转存中…(img-1zak8I5G-1712627212461)]

[外链图片转存中…(img-OUzyJriT-1712627212461)]

《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值