微信小程序获取用户openid,头像昵称信息,后台java代码

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_39851704/article/details/79025557

小程序前端 app.js

 

wx.login({

      success: res => {

        // 发送 res.code 到后台换取 openId, sessionKey, unionId

        if(res.code){

          wx.getUserInfo({

            success: function(res_user){

              wx.request({

                url: 'http://192.168.xx.xx:8080/test/v1/getOpenId', //这里是本地请求路径,可以写你自己的本地路径,也可以写线上环境

                data: {

                  code: res.code,//获取openid的话 需要向后台传递code,利用code请求api获取openid

                  headurl: res_user.userInfo.avatarUrl,//这些是用户的基本信息

                  nickname:res_user.userInfo.nickName,//获取昵称

                  sex:res_user.userInfo.gender,//获取性别

                  country: res_user.userInfo.country,//获取国家

                  province: res_user.userInfo.province,//获取省份

                  city: res_user.userInfo.city//获取城市

                },

                success: function(res){

                  wx.setStorageSync("openid", res.data)//可以把openid保存起来,以便后期需求的使用

                }

              })

            }

          })

        }

      }

    })

 

一些详细的参数请参考微信api:https://mp.weixin.qq.com/debug/wxadoc/dev/api/open.html#wxgetuserinfoobject

 

 

下来就是Java     上面这是controller,其中有些地方也是取别人的优点写的 

 

	@ResponseBody
	@RequestMapping(value = "/getOpenId", method = RequestMethod.GET) // 获取用户信息
	public String getOpenId(@Param("code") String code, @RequestParam("headurl") String headurl,
			@RequestParam("nickname") String nickname, @RequestParam("sex") String sex,
			@RequestParam("country") String country, @RequestParam("province") String province,
			@RequestParam("city") String city) {
		String WX_URL = "https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code";
		try {
			if (StringUtils.isBlank(code)) {
				System.out.println("code为空");
			} else {
				String requestUrl = WX_URL.replace("APPID", WxConfig.APPID).replace("SECRET", WxConfig.APPSECRECT)
						.replace("JSCODE", code).replace("authorization_code", WxConfig.GRANTTYPE);
				JSONObject jsonObject = CommonUtil.httpsRequest(requestUrl, "GET", null);
				if (jsonObject != null) {
					try {
						// 业务操作
						String openid = jsonObject.getString("openid");
						wechatService.selectUserByOpenId(openid, headurl, nickname, sex, country, province, city);
						return openid;
					} catch (Exception e) {
						System.out.println("业务操作失败");
						e.printStackTrace();
					}
				} else {
					System.out.println("code无效");
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
		return "错误";
	}  //可能代码复制过来,错位了,你们自己格式化一下吧。

    首先获取openid根据文档需要访问一个https接口 如下:

https://api.weixin.qq.com/sns/jscode2session?appid=APPID&secret=SECRET&js_code=JSCODE&grant_type=authorization_code

 

appid是你小程序的appid,secret是你小程序的appsercet,js_code是前台登陆成功后返回给你的code,grant_type为固定值authorization_code.

 

appid跟secret的查看在微信公众平台:https://mp.weixin.qq.com/

 

注意:appid跟secret只有小程序的管理员可以看到,如果只是有权限的话,还是看不到,必须管理员扫码才可以看到,进去之后就在 设置→→→开发设置

 

 controller中涉及到三个类,CommonUtil是用来请求微信接口的,TrustManager是管理器,WxConfig是配置一些你的小程序   信息

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
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.JSONObject;

public class CommonUtil {
	/**
     * 发送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) {
            System.out.println("连接超时");
        } catch (Exception e) {
            System.out.println("请求异常");
        }
        return jsonObject;
    }
}

 

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

import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

/**
 * 类名: MyX509TrustManager.java</br> 
 * 描述: 信任管理器</br> 
 * 开发人员:wangl</br>
 * 创建时间: 2018-01-09</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;
    }
}


   

有了这两个类就可以获取到用户的openid了,大家都知道,保存用户的昵称跟头像是没什么用的,但是需求有需要,只好保存 了,下面我贴出业务层代码,哈哈哈哈哈,我只是在瞎搞,自己练习,如果代码有什么可笑的地方不要喷我。

 

    如果用户更换了头像或者昵称,我们并不知道用户什么时候更换,所以我想了一种方法,判断用户是否改变数据,如果改变数据的话,我们再进行数据库的操作,如果不改变的话直接return返回,结束操作。

   下面这段代码是ServiceImpl类。

public void selectUserByOpenId(String openid, String headurl, String nickname, String sex, String country,
			String province, String city) {
			String userip = country+province+city;//用户地址
			String usersex = "";
			User user = mapper.selectUser(openid);
			if(user!=null){//如果用户不等于空
				if(user.getNickname().equals(nickname)&&user.getHeadurl().equals(headurl)&&user.getSex().equals(sex)&&user.getUserip().equals(userip)){
					System.out.println("数据暂未修改");
					return;
				}else{
					try {
						mapper.updateUserMseeage(openid,nickname,headurl,sex,userip);
						System.out.println("修改数据成功");
					} catch (Exception e) {
						System.out.println("修改数据失败");
						e.printStackTrace();
					}
					
				}
			}else{//用户为空进行
				try {
					String phone = "";
					String createtime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
					mapper.initUser(openid,nickname,headurl,phone,sex,userip,createtime);
				} catch (Exception e) {
					System.out.println("初始化错误");
					e.printStackTrace();
				}
			}
	}

 

QQ:434494584

关于微信公众号获取openId,请点击https://blog.csdn.net/qq_39851704/article/details/89174501

 

 

 

 


 

 

展开阅读全文

没有更多推荐了,返回首页