微信授权(一)测试号申请,以及环境配置

一: 申请测试账号

https://mp.weixin.qq.com/debug/cgi-bin/sandboxinfo?action=showinfo&t=sandbox/index

二:填写相关信息:

  1.自己本地服务器映射, 必须80端口, 通过花生壳可做映射

  2. 填写 H5存放域名 也可以放到本地

微信授权(一)测试号申请,以及环境配置_第1张图片

3关注测试号,扫描二维码即可

微信授权(一)测试号申请,以及环境配置_第2张图片

4.配置页面授权地址

微信授权(一)测试号申请,以及环境配置_第3张图片

微信授权(一)测试号申请,以及环境配置_第4张图片

微信授权(一)测试号申请,以及环境配置_第5张图片

需要服务器响应:

代码:

@RequestMapping(value="checkSignature",method= RequestMethod.GET)
    @ResponseBody
    public String getJson(HttpServletRequest request, HttpServletResponse response) {
        log.info("start checkSignature!");
        String signature = request.getParameter("signature");
        // 时间戳
        String timestamp = request.getParameter("timestamp");
        // 随机数
        String nonce = request.getParameter("nonce");
        // 随机字符串
        String echostr = request.getParameter("echostr");
        // 通过检验signature对请求进行校验,若校验成功则原样返回echostr,表示接入成功,否则接入失败
        if (SignUtil.checkSignature(signature, timestamp, nonce)) {
            log.info("连接成功");
        }
        return echostr;
    }

SignUtil:

package com.chutian.common.utils.wechat;


import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;

/**
 * 请求校验工具类
 * @author 刘大帅
 *
 */
public class SignUtil {
    /**
     * 与接口配置信息中的Token要一致
     */
    private static String token = "weixin";  

    /** 
     * 验证签名 
     *  
     * @param signature 
     * @param timestamp 
     * @param nonce 
     * @return 
     */  
    public static boolean checkSignature(String signature, String timestamp, String nonce) {  
        String[] arr = new String[] { token, timestamp, nonce };  
        // 将token、timestamp、nonce三个参数进行字典序排序  
        Arrays.sort(arr);  
        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;  
        // 将sha1加密后的字符串可与signature对比,标识该请求来源于微信  
        return tmpStr != null ? tmpStr.equals(signature.toUpperCase()) : false;  
    }  

    /** 
     * 将字节数组转换为十六进制字符串 
     *  
     * @param byteArray 
     * @return 
     */  
    private static String byteToStr(byte[] byteArray) {  
        String strDigest = "";  
        for (int i = 0; i < byteArray.length; i++) {  
            strDigest += byteToHexStr(byteArray[i]);  
        }  
        return strDigest;  
    }  

    /** 
     * 将字节转换为十六进制字符串 
     *  
     * @param mByte 
     * @return 
     */  
    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;  
    }  
}

 

三 通过url 调用授权

https://open.weixin.qq.com/connect/oauth2/authorize?appid=wxabc670e3c404adf9&redirect_uri=http%3A%2F%2F1864rg4803.imwork.net%2F%2FweChat%2FgetCode&response_type=code&scope=snsapi_userinfo&state=students-photo.html

地址说明:

appid:测试号申请后的appid

redirect_uri: 微信响应回调的地址(网页授权填写的是域名+方法名)

response_type: 固定的 code

scope: 静默授权和非静默授权

state: 返回的H5页面

你可能感兴趣的:(JAVA)