新手上路之获取微信用户信息两种方案第一种

博主正在做微信的一个项目,需要用到得到用户授权、获取微信用户个人信息......在这里简明地分享给大家

标题里面说有两种方案,下面我具体说明这两种方案:

一.通过在公众号测试账号获取openid

这种方案用于测试代码,将自己的微信号当作示例进行测试,缺点是只能通过特定的openid来获取用户信息,那么今天博主就仔细讲下这种方式。

首先获取自己的AppID,AppSecret→获取accessToken→获取openid→获取个人信息

首先使用自己的微信弄一个测试账号,然后获取appid和appsecret

这里是appid和appsecret,拷贝下来放在记事本上记下来或者代码里记下来

接着打开微信公众平台开发者工具,获取accessToken

选择基础支持→获取token→输入刚刚测试账号的appid和appsecret显示校验通过,点击检查问题,如果没有问题就会返回成功

记下access_token在记事本上保存,接下来获取openid

同样在线接口调试

用户管理→获取关注着接口列表

这里的next_openid不用填写,access_token即是刚刚获取到的,点击检查问题

记住获取到的openid,然后记在记事本上,下面我们开始写代码了

首先我们创建一个微信类,同时数据库也建一个相应的表

public class WeixinUserInfo {

	// 用户的标识
    private String openId;
    // 关注状态(1是关注,0是未关注),未关注时获取不到其余信息
    private int subscribe;
    // 用户关注时间,为时间戳。如果用户曾多次关注,则取最后关注时间
    private String subscribeTime;
    // 昵称
    private String nickname;
    // 用户的性别(1是男性,2是女性,0是未知)
    private int sex;
    // 用户所在国家
    private String country;
    // 用户所在省份
    private String province;
    // 用户所在城市
    private String city;
    // 用户的语言,简体中文为zh_CN
    private String language;
    // 用户头像
    private String headImgUrl;
	public String getOpenId() {
		return openId;
	}
	public void setOpenId(String openId) {
		this.openId = openId;
	}
	public int getSubscribe() {
		return subscribe;
	}
	public void setSubscribe(int subscribe) {
		this.subscribe = subscribe;
	}
	public String getSubscribeTime() {
		return subscribeTime;
	}
	public void setSubscribeTime(String subscribeTime) {
		this.subscribeTime = subscribeTime;
	}
	public String getNickname() {
		return nickname;
	}
	public void setNickname(String nickname) {
		this.nickname = nickname;
	}
	public int getSex() {
		return sex;
	}
	public void setSex(int sex) {
		this.sex = sex;
	}
	public String getCountry() {
		return country;
	}
	public void setCountry(String country) {
		this.country = country;
	}
	public String getProvince() {
		return province;
	}
	public void setProvince(String province) {
		this.province = province;
	}
	public String getCity() {
		return city;
	}
	public void setCity(String city) {
		this.city = city;
	}
	public String getLanguage() {
		return language;
	}
	public void setLanguage(String language) {
		this.language = language;
	}
	public String getHeadImgUrl() {
		return headImgUrl;
	}
	public void setHeadImgUrl(String headImgUrl) {
		this.headImgUrl = headImgUrl;
	}
    
}

接着给token建一个类用于给定token的有效时长,因为token是会过期的

public class Token {

	// 接口访问凭证
	private String accessToken;
	// 凭证有效期,单位:秒
	private int expiresIn;

	public String getAccessToken() {
		return accessToken;
	}

	public void setAccessToken(String accessToken) {
		this.accessToken = accessToken;
	}

	public int getExpiresIn() {
		return expiresIn;
	}

	public void setExpiresIn(int expiresIn) {
		this.expiresIn = expiresIn;
	}

}

接下来建一个公共类获取凭证

package com.jxjc.utils;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.UnsupportedEncodingException;
import java.net.ConnectException;
import java.net.URL;

import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;

import net.sf.json.JSONException;
import net.sf.json.JSONObject;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.jxjc.domain.Token;


/*
 * 通用工具类
 */
public class CommonUtil {

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

    // 凭证获取(GET)
    public final static String token_url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET";

    /**
     * 发送https请求
     * 
     * @param requestUrl 请求地址
     * @param requestMethod 请求方式(GET、POST)
     * @param outputStr 提交的数据
     * @return JSONObject(通过JSONObject.get(key)的方式获取json对象的属性值)
     */
    public static JSONObject httpsRequest(String requestUrl, String requestMethod, String outputStr) {
        JSONObject jsonObject = null;
        try {
            // 创建SSLContext对象,并使用我们指定的信任管理器初始化
            TrustManager[] tm = { new MyX509TrustManager() };
            SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
            sslContext.init(null, tm, new java.security.SecureRandom());
            // 从上述SSLContext对象中得到SSLSocketFactory对象
            SSLSocketFactory ssf = sslContext.getSocketFactory();

            URL url = new URL(requestUrl);
            HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
            conn.setSSLSocketFactory(ssf);
            
            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.setUseCaches(false);
            // 设置请求方式(GET/POST)
            conn.setRequestMethod(requestMethod);

            // 当outputStr不为null时向输出流写数据
            if (null != outputStr) {
                OutputStream outputStream = conn.getOutputStream();
                // 注意编码格式
                outputStream.write(outputStr.getBytes("UTF-8"));
                outputStream.close();
            }

            // 从输入流读取返回内容
            InputStream inputStream = conn.getInputStream();
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "utf-8");
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String str = null;
            StringBuffer buffer = new StringBuffer();
            while ((str = bufferedReader.readLine()) != null) {
                buffer.append(str);
            }

            // 释放资源
            bufferedReader.close();
            inputStreamReader.close();
            inputStream.close();
            inputStream = null;
            conn.disconnect();
            jsonObject = JSONObject.fromObject(buffer.toString());
        } catch (ConnectException ce) {
            log.error("连接超时:{}", ce);
        } catch (Exception e) {
            log.error("https请求异常:{}", e);
        }
        return jsonObject;
    }

    /**
     * 获取接口访问凭证
     * 
     * @param appid 凭证
     * @param appsecret 密钥
     * @return
     */
    public static Token getToken(String appid, String appsecret) {
        Token token = null;
        String requestUrl = token_url.replace("APPID", appid).replace("APPSECRET", appsecret);
        // 发起GET请求获取凭证
        JSONObject jsonObject = httpsRequest(requestUrl, "GET", null);

        if (null != jsonObject) {
            try {
                token = new Token();
                token.setAccessToken(jsonObject.getString("access_token"));
                token.setExpiresIn(jsonObject.getInt("expires_in"));
            } catch (JSONException e) {
                token = null;
                // 获取token失败
                log.error("获取token失败 errcode:{} errmsg:{}", jsonObject.getInt("errcode"), jsonObject.getString("errmsg"));
            }
        }
        return token;
    }
    
    /**
     * URL编码(utf-8)
     * 
     * @param source
     * @return
     */
    public static String urlEncodeUTF8(String source) {
        String result = source;
        try {
            result = java.net.URLEncoder.encode(source, "utf-8");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return result;
    }
    
    /**
     * 根据内容类型判断文件扩展名
     * 
     * @param contentType 内容类型
     * @return
     */
    public static String getFileExt(String contentType) {
        String fileExt = "";
        if ("image/jpeg".equals(contentType))
            fileExt = ".jpg";
        else if ("audio/mpeg".equals(contentType))
            fileExt = ".mp3";
        else if ("audio/amr".equals(contentType))
            fileExt = ".amr";
        else if ("video/mp4".equals(contentType))
            fileExt = ".mp4";
        else if ("video/mpeg4".equals(contentType))
            fileExt = ".mp4";
        return fileExt;
    }
}

建一个信任管理器

package com.jxjc.utils;

import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;

import javax.net.ssl.X509TrustManager;

/**
* 类名: MyX509TrustManager </br>
* 描述:信任管理器 </br>
 */
public class MyX509TrustManager implements X509TrustManager {

	// 检查客户端证书
    public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    }

    // 检查服务器端证书
    public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    }

    // 返回受信任的X509证书数组
    public X509Certificate[] getAcceptedIssuers() {
        return null;
    }
}

接下来万事俱备就可以获取用户信息了,该类写在controller里面,按照个人意愿即可

/*
	 * 获取用户信息
	 */
	 public static WeixinUserInfo getUserInfo(String accessToken, String openId) {
	        WeixinUserInfo weixinUserInfo = null;
	        // 拼接请求地址
	        String requestUrl = "https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID";
	        requestUrl = requestUrl.replace("ACCESS_TOKEN", accessToken).replace("OPENID", openId);
	        // 获取用户信息
	        JSONObject jsonObject = CommonUtil.httpsRequest(requestUrl, "GET", null);

	        if (null != jsonObject) {
	            try {
	                weixinUserInfo = new WeixinUserInfo();
	                // 用户的标识
	                weixinUserInfo.setOpenId(jsonObject.getString("openid"));
	                // 关注状态(1是关注,0是未关注),未关注时获取不到其余信息
	                weixinUserInfo.setSubscribe(jsonObject.getInt("subscribe"));
	                // 用户关注时间
	                weixinUserInfo.setSubscribeTime(jsonObject.getString("subscribe_time"));
	                // 昵称
	                weixinUserInfo.setNickname(jsonObject.getString("nickname"));
	                // 用户的性别(1是男性,2是女性,0是未知)
	                weixinUserInfo.setSex(jsonObject.getInt("sex"));
	                // 用户所在国家
	                weixinUserInfo.setCountry(jsonObject.getString("country"));
	                // 用户所在省份
	                weixinUserInfo.setProvince(jsonObject.getString("province"));
	                // 用户所在城市
	                weixinUserInfo.setCity(jsonObject.getString("city"));
	                // 用户的语言,简体中文为zh_CN
	                weixinUserInfo.setLanguage(jsonObject.getString("language"));
	                // 用户头像
	                weixinUserInfo.setHeadImgUrl(jsonObject.getString("headimgurl"));
	            } catch (Exception e) {
	                if (0 == weixinUserInfo.getSubscribe()) {
	                	System.out.println("---------------------用户已取消关注--------------------------------");
	                } else {
	                    int errorCode = jsonObject.getInt("errcode");
	                    String errorMsg = jsonObject.getString("errmsg");
	                    System.out.println("---------------------获取用户信息失败--------------------------------");
	                }
	            }
	        }
	        return weixinUserInfo;
	    }

我们来获取访问接口凭证、获取用户信息、并输出一下,这里需要注意,因为博主目前用的是第一种方案,用获取到的openid来获取用户信息,并不是通过用户授权,因此调用方法的时候记得参数改为自己的openid

public static void getweChat_message(WeixinUserInfo user) {
		// 获取接口访问凭证
	        String accessToken = 
	        	CommonUtil.getToken("wxe5a98acba7d75120", "5c949873fb5b825d61a13688c5fc1a5c").getAccessToken();
	        /**
	         * 获取用户信息
	         */
	        user = getUserInfo(accessToken, "o0BjI1YTbExy4W9qIKq6LFwJ8cs0");
	        System.out.println("OpenID:" + user.getOpenId());
	        System.out.println("关注状态:" + user.getSubscribe());
	        System.out.println("关注时间:" + user.getSubscribeTime());
	        System.out.println("昵称:" + user.getNickname());
	        System.out.println("性别:" + user.getSex());
	        System.out.println("国家:" + user.getCountry());
	        System.out.println("省份:" + user.getProvince());
	        System.out.println("城市:" + user.getCity());
	        System.out.println("语言:" + user.getLanguage());
	        System.out.println("头像:" + user.getHeadImgUrl());
	 }

好了我们在需要调用到获取信息的方法里面调用一下

WeixinUserInfo userlist = new WeixinUserInfo();
		userController uc = new userController();
		uc.getweChat_message(userlist);

最后我们来看看效果

这就是博主的微信号信息了

欢迎大家关注我的CSDN博客,定时推送博主的学习历程哦!

今天说到这里,下面会继续将关于第二种方式,通过用户授权来获取用户信息!

猜你喜欢

转载自blog.csdn.net/MengDiL_yl/article/details/81188747