最全Java搭建微信公众号的服务器配置,Java开发新手入门教程

最后

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

登录微信公众平台官网后,在公众平台官网的开发-基本设置页面,勾选协议成为开发者,点击“修改配置”按钮,填写服务器地址(URL)、Token和EncodingAESKey,其中URL是开发者用来接收微信消息和事件的接口URL。Token可由开发者可以任意填写,用作生成签名(该Token会和接口URL中包含的Token进行比对,从而验证安全性)。EncodingAESKey由开发者手动填写或随机生成,将用作消息体加解密密钥。

同时,开发者可选择消息加解密方式:明文模式、兼容模式和安全模式。模式的选择与服务器配置在提交后都会立即生效,请开发者谨慎填写及选择。加解密方式的默认状态为明文模式,选择兼容模式和安全模式需要提前配置好相关加解密代码,详情请参考消息体签名及加解密部分的文档 。

第二步:验证消息的确来自微信服务器


开发者提交信息后,微信服务器将发送GET请求到填写的服务器地址URL上,GET请求携带参数如下表所示:

| 参数 | 描述 |

| — | — |

| signature | 微信加密签名,signature结合了开发者填写的token参数和请求中的timestamp参数、nonce参数。 |

| timestamp | 时间戳 |

| nonce | 随机数 |

| echostr | 随机字符串 |

我使用的是java验证

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.

*/

最后希望可以帮助到大家!

千千万万要记得:多刷题!!多刷题!!

之前算法是我的硬伤,后面硬啃了好长一段时间才补回来,算法才是程序员的灵魂!!!!

篇幅有限,以下只能截图分享部分的资源!!

(1)多线程(这里以多线程为代表,其实整理了一本JAVA核心架构笔记集)

image

(2)刷的算法题(还有左神的算法笔记)

image

(3)面经+真题解析+对应的相关笔记(很全面)

image

(4)视频学习(部分)

ps:当你觉得学不进或者累了的时候,视频是个不错的选择

在这里,最后只一句话:祝大家offer拿到手软!!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

句话:祝大家offer拿到手软!!

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值