百科狗-知识改变命运!
--

javaopenid换微信昵称

泡在奶味里1年前 (2023-12-10)阅读数 8#抖音技巧
文章标签用户程序

小程序前端 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

* 描述: 信任管理器

* 开发人员:wangl

* 创建时间: 2018-01-09

*/

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

小程序获取openid加java后台代码

小程序

小程序java后台

属羊人要“沉住气”,别跟这个人分开,是来“拥护”你成事的

麦玲玲仅供娱乐

广告

微信小程序wx.getUserInfo授权获取用户信息(头像、昵称)的实现

37下载·0评论

2020年10月14日

java微信小程序授权 获取用户信息、获取openid和session_key 获取用户unionId、(用户数据的签名验证和加解密)JAVA版

5.8W阅读·63评论·42点赞

2018年5月9日

Java后台实现网站微信扫码登录功能,获取用户openid,及微信用户信息(小程序码方案),关联微信小程序(个人主体小程序也可以)

1098阅读·0评论·2点赞

2022年10月26日

微信小程序请求后台接口(完整版)

1.5W阅读·0评论·17点赞

2020年7月20日

java实现微信授权获取用户openid及授权用户相关信息

2.2W阅读·12评论·5点赞

2018年1月9日

java微信获取用户信息_Java微信公众平台开发(十)--微信用户信息的获取

252阅读·0评论·0点赞

2021年2月12日

电马新能源车24.99万元起,现车交付!

电马新能源车

广告

微信小程序获取用户信息(昵称、头像、openid等)

8480阅读·2评论·2点赞

2021年6月22日

通过微信用户的openid获取用户的头像,昵称,性别等信息!

7.3W阅读·6评论·5点赞

2018年7月16日

java 根据openid查询_java 根据openId获取用户基本信息

1060阅读·0评论·0点赞

2021年3月16日

java后端实现微信登录获取code,后端获取code、openid以及用户信息数据

5662阅读·8评论·1点赞

2021年11月30日

微信小程序如何获取微信昵称和头像

1.7W阅读·2评论·8点赞

2022年3月1日

java获取微信用户openid

1.3W阅读·1评论·0点赞

2018年7月6日

微信小程序获取用户信息(getUserProfile接口回收后)——通过头像昵称填写获取用户头像和昵称

724阅读·0评论·0点赞

2022年11月24日

java获取openid_JAVA获取微信小程序openid和获取公众号openid,以及通过openid获取用户信息...

1229阅读·0评论·0点赞

2021年2月12日

java后台微信小程序获取手机号

1794阅读·1评论·1点赞

2020年9月25日

微信小程序——获取用户手机号(Java后台)

1285阅读·0评论·1点赞

2022年8月25日

java微信小程序获取用户openid_微信小程序授权获取用户详细信息openid的实例详解...

632阅读·0评论·0点赞

javaopenid换微信昵称

2021年3月8日

java微信开发-之如何获取openid 和用户信息

3.5W阅读·18评论·8点赞

2016年12月6日

微信公众号H5获取用户openid等用户信息(java)

1182阅读·1评论·3点赞

2021年11月4日

去首页

看看更多热门内容

评论14

for__rain

就这个发送http请求,看了一堆憨憨的操作,总算找到这个好用的啦,谢谢

2019.10.21

烟雨惊蛰

[code=java] //帮你们补上WxConfig public class WxConfig { public static String APPID = "你的APPID "; public static String APPSECRECT = "你的APPSECRECT "; public static String GRANTTYPE = "你的GRANTTYPE "; } [/code]

2019.04.09

萨埵十二

大哥您好,我想请问一下,没有appid可以获取用户的openid么?

用OpenID绑定即可

微信接口中虽然没给用户的微信账号,但给了用户的OpenID,这个OpenID对一个公众号是唯一的,测试也证明不会改变,也就是说同一个微信号和同一个公众号交互,我们得到的OpenID是不会变的,因此,可以用OpenID作为微信用户的身份标识。

如何绑定

俗话说,没吃过猪肉还没见过猪跑。看招行信用卡公众号是如何做的,在微信里面给用户一个验证链接,用户点击链接,微信会用内嵌的浏览器打开这个链接,然后就是一般的网页登录验证界面,我们通过HTTP(S)获取用户输入的系统用户名与密码,验证通过后完成绑定。 具体如何生成链接和如何传递OpenID下面详述。

如何生成绑定链接

绑定涉及到用户的身份甚至利益,所以需要注意安全性。我们需要绑定的是OpenID和系统用户,系统用户名是用户直接在链接页面输入后通过 HTTP(S)传给我们的,这没有问题。OpenID对用户来说透明,用户不会传给我们,我们也只有在用户在微信中向公众号发消息时才可获得 OpenID,所以很明显,OpenID需要包含在生成的链接中,至于需不需要对OpenID作加密就看你自己了,我觉得这不重要,更为重要的是要在链接 中带上签名和加上时间戳。因为我们需要确认这个链接是由我们服务端生成的,用户自己或者其他人不能够伪造出这个链接,加上时间戳是为了给这个链接一个过期 时间,如果不限制过期时间,假设用户绑定后这个链接通过某种方式被别人知道,那么这个人就可以把自己的账号与用户的微信号绑定。所以我采取的方法是用 OpenID、过期时间再加上一个密钥生成签名,生成签名的方法和微信服务器接口验证时的签名方法类似(密钥最好另选一个只有自己知道的)。

如何传递OpenID

有了绑定链接,用户点了绑定链接,但这只是第一步,第二步我们需要在用户在链接页面提交登录请求后进行验证,OpenID怎么传到第二步中呢?有人 说了,这还不简单,在登录表单中加一个隐藏域放用户的OpenID一起提交给验证的Handler不就OK了,那我只能说很遗憾,你前面所做的安全工作都 白费了,一旦A用户的OpenID泄漏,B用户就可以把自己的账号与A用户的微信号绑定了。所以永远不要相信客户端提交的东西。我的方法是当用户点击生成 链接后,在链接页载入时,将OpenID存到session中,因为这个session是没法伪造的(cookie被盗除外),所以只有点击这个链接的用 户的session中才会有链接中包含的OpenID。

鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com

免责声明:我们致力于保护作者版权,注重分享,当前被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理!邮箱:344225443@qq.com)

图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

内容声明:本文中引用的各种信息及资料(包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主体(包括但不限于公司、媒体、协会等机构)的官方网站或公开发表的信息。部分内容参考包括:(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供参考使用,不准确地方联系删除处理!本站为非盈利性质站点,本着为中国教育事业出一份力,发布内容不收取任何费用也不接任何广告!)