关于微信公众号服务器设置token的问题

来源:互联网 发布:淘宝上卖旅游产品 编辑:程序博客网 时间:2024/05/16 11:53

我只是个不懂后台的菜鸡,所以出现了一些很菜鸡的错误,就算跟着大牛抄代码,微信还是没提示我成功,下面是我的一个坑。

1.像微信文档所描述,你需要给一个服务器的url,然后随便写一个token,然后选择加密模式,然后提交。然后你就很随意的写了一个,然后提交,然后就提示“token校验失败”。

然后你就一直在浏览器测试你的地址,可以啊,完全没问题啊,可以访问到啊,what?什么鬼,难道是骗我的,说好的随意写一个呢。

2.出现这样问题的原因是微信给了你“echostr”字段的数值,但是你并没有返回给他,他拿不到数据,他就一直失败。

参考如下博客:http://www.cnblogs.com/liuhongfeng/p/4846441.html,如果我直接抄了他的就行了,我就不会再写这个了,so,你去看吧,去看了之后成功了,那就不用再来了,还不行的话,也许你还可以继续看下去。

好了,你也看了,但是如果你还是不行,那再来看吧,如果你连地址映射的方法都跟他的一样(对于服务器我是sunny-nyrok进行地址映射的),然后还不行,那我就不知道了,但是如果你只是去看了项目结构和方法,然后不行,那你可以看看我的坑。

对于,java文件代码,和上面的博客相同,index.jsp也大概相同,毕竟这个不是关键点。

对于index.jsp和web.xml的配置,我的HttpServlet的路径是com.test.MyServer;配置如下(完全就是照抄):

<%@ page language="java" contentType="text/html; charset=utf-8"    pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>Insert title here</title></head><body>This my own Test!</body></html>

<?xml version="1.0" encoding="UTF-8"?><web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">  <display-name>TestWeChat</display-name>  <welcome-file-list>    <welcome-file>index.html</welcome-file>    <welcome-file>index.htm</welcome-file>    <welcome-file>index.jsp</welcome-file>    <welcome-file>default.html</welcome-file>    <welcome-file>default.htm</welcome-file>    <welcome-file>default.jsp</welcome-file>  </welcome-file-list>  <servlet>        <servlet-name>myServer</servlet-name>        <servlet-class>           com.mytest.MyServer        </servlet-class>    </servlet>      <!-- url-pattern中配置的/coreServlet用于指定该Servlet的访问路径 -->    <servlet-mapping>        <servlet-name>myServer</servlet-name>        <url-pattern>/myServer</url-pattern>    </servlet-mapping></web-app>
然后,我的项目名称叫做MyTestWechat,当你上面都设置完了,然后在浏览器打开:http://我的域名/MyTestWechat,不出意外的话,这个地址是可以访问的,而且展示的内容是你index.jsp的内容,然后你继续美滋滋的把这个地址和你的token放到了微信里面,然后再提交了一下,然后你会发现,what a fuck,依旧不行,什么鸡,那就是你没有拼接上你配置的myServer了,至于为啥,我也不知道 我也正在学,反正你先实现功能再说了。然后再次提交,很nice,成功了。

3.具体的代码如下:

package com.mytest;import java.io.IOException;import java.io.PrintWriter;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;public class MyServer extends HttpServlet{ private static final long serialVersionUID = 4323197796926899691L;    /**     * 确认请求来自微信服务器     */    public void doGet(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        System.out.print("=====================");        // 微信加密签名        String signature = request.getParameter("signature");        // 时间戳        String timestamp = request.getParameter("timestamp");        // 随机数        String nonce = request.getParameter("nonce");        // 随机字符串        String echostr = request.getParameter("echostr");System.out.println("sign:"+signature+";time:"+timestamp+";nonce:"+nonce+";echostr"+echostr);        PrintWriter out = response.getWriter();        //这里是我自己的测试使用的,不是微信时需要使用的方法        if(signature.equals("1")) {        //这里是返回的信息        out.print("1111111");        }        // 通过检验signature对请求进行校验,若校验成功则原样返回echostr,表示接入成功,否则接入失败        if (MyCheck.checkSignature(signature, timestamp, nonce)) {            out.print(echostr);        }                out.close();        out = null;    }    /**     * 处理微信服务器发来的消息     */    public void doPost(HttpServletRequest request, HttpServletResponse response)            throws ServletException, IOException {        // TODO 消息的接收、处理、响应    }}
package com.mytest;import java.security.MessageDigest;import java.security.NoSuchAlgorithmException;import java.util.Arrays;public class MyCheck {public static final String  token = "shb2058"; //开发者自行定义Tooken    /**    * 方法名:checkSignature</br>    * 详述:验证签名</br>    * 开发人员:souvc</br>    * 创建时间:2015-9-29  </br>    * @param signature    * @param timestamp    * @param nonce    * @return    * @throws     */    public static boolean checkSignature(String signature, String timestamp,String nonce) {        // 1.将token、timestamp、nonce三个参数进行字典序排序        String[] arr = new String[] { token, timestamp, nonce };        Arrays.sort(arr);                // 2. 将三个参数字符串拼接成一个字符串进行sha1加密        StringBuilder content = new StringBuilder();        for (int i = 0; i < arr.length; i++) {            content.append(arr[i]);        }        MessageDigest md = null;        String tmpStr = null;        try {            md = MessageDigest.getInstance("SHA-1");            // 将三个参数字符串拼接成一个字符串进行sha1加密            byte[] digest = md.digest(content.toString().getBytes());            tmpStr = byteToStr(digest);        } catch (NoSuchAlgorithmException e) {            e.printStackTrace();        }                content = null;        // 3.将sha1加密后的字符串可与signature对比,标识该请求来源于微信        return tmpStr != null ? tmpStr.equals(signature.toUpperCase()) : false;    }    /**    * 方法名:byteToStr</br>    * 详述:将字节数组转换为十六进制字符串</br>    * 开发人员:souvc </br>    * 创建时间:2015-9-29  </br>    * @param byteArray    * @return    * @throws     */    private static String byteToStr(byte[] byteArray) {        String strDigest = "";        for (int i = 0; i < byteArray.length; i++) {            strDigest += byteToHexStr(byteArray[i]);        }        return strDigest;    }    /**    * 方法名:byteToHexStr</br>    * 详述:将字节转换为十六进制字符串</br>    * 开发人员:souvc</br>    * 创建时间:2015-9-29  </br>    * @param mByte    * @return    * @throws     */    private static String byteToHexStr(byte mByte) {        char[] Digit = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A','B', 'C', 'D', 'E', 'F' };        char[] tempArr = new char[2];        tempArr[0] = Digit[(mByte >>> 4) & 0X0F];        tempArr[1] = Digit[mByte & 0X0F];        String s = new String(tempArr);        return s;    }}


阅读全文
1 0
原创粉丝点击