进行微信公众号的开发:
1.我们需要有微信公众号(开发中我们可以自己去申请一个个人的公众号进行测试开发),
2.需要一个公网的IP(对于开发阶段便于我们调试,我们可以使用ngrok,进行一个内网穿透,将本地IP映射成公网的IP,使用80端口),开发时候,我们将Tomcat端口设置为80;
3.里面所涉及到的工具类,在我的常用工具类中,我有进行展示说明,直接Copy
-------------------------------------------------------开始微信后台------------------------------------------------------------------
开发微信公众号,必须进入微信公众号平台中,进行url 和token 的配置,这个url就是我们与微信后台交互的路径,我们主要就是开发这个url;
APPID 以及AppSecret 会自动生成,在我们开发中我们会用的到,进行校验
配置url,这个url是微信Get请求到我们服务器的地址,且为公网可以访问的地址;
自定义一个token,后面代码有用
---------------------------------------------编写微信Get请求的后台校验代码(******重要的一步)---------------------------------------------------
/*controller
* 该方法与微信后台配置的url进行对接,是get的请求,是微信开发的第一步
* 微信后台会给我们接口传入signature,timestamp,nonce,echostr
* 进行sha1 加密与signature比较,TRUE 则返回echostr给微信
* author:cys
*/
@RequestMapping(value="/wxopen" ,method=RequestMethod.GET)
public void wxopen(HttpServletResponse response,String signature,String timestamp,String nonce,String echostr) {
PrintWriter writer=null;
//微信检验逻辑处理,这里涉及到一些算法以及加密,不用去研究它,复制就行
if(WxOpenCheck.checkSignature(signature, timestamp, nonce)) {
try {
writer=response.getWriter();
writer.write(echostr);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
finally {
if(writer !=null) {
writer.close();
}
}
}
}
微信检验逻辑
package com.wx.project.util;
import java.util.Arrays;
public class WxOpenCheck {
//微信参数进行校验的逻辑
public static boolean checkSignature(String signature,String timestamp,String nonce) {
//后台自己定义的Token,开发者需要自己修改的地方
String token ="chenyuesong";
String arr[]= new String[] {token,timestamp,nonce};
//排序
Arrays.sort(arr);
StringBuilder builder =new StringBuilder();
for(int i=0;i<arr.length;i++) {
builder.append(arr[i]);
}
//sha1 加密
String sha1=SHA1.encode(builder.toString());
return sha1.equals(signature);
}
}
sha1加密工具类,直接copy
package com.wx.project.util;
import java.security.MessageDigest;
/*
* sha1 加密算法
* 网上copy 一大堆
*/
public class SHA1 {
private static final char[] HEX_DIGITS = {'0', '1', '2', '3', '4', '5',
'6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'};
/**
* Takes the raw bytes from the digest and formats them correct.
*
* @param bytes the raw bytes from the digest.
* @return the formatted bytes.
*/
private static String getFormattedText(byte[] bytes) {
int len = bytes.length;
StringBuilder buf = new StringBuilder(len * 2);
// 把密文转换成十六进制的字符串形式
for (int j = 0; j < len; j++) {
buf.append(HEX_DIGITS[(bytes[j] >> 4) & 0x0f]);
buf.append(HEX_DIGITS[bytes[j] & 0x0f]);
}
return buf.toString();
}
public static String encode(String str) {
if (str == null) {
return null;
}
try {
MessageDigest messageDigest = MessageDigest.getInstance("SHA1");
messageDigest.update(str.getBytes());
return getFormattedText(messageDigest.digest());
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
代码写好之后,在80端口运行,在微信后台中将我们的写好的接口url接口配置上,点击提交,只要代码没有错误,就会成功。
这样我们的第一步就完成了,微信和我们的后台就是打通了-----