JAVA——微信小程序获取用户的openId

博客分享了微信小程序获取用户OpenId方法的核心代码,并非完整class类,跟着思路看就能掌握,完成获取操作后基本复制代码即可,同时提醒要记得导包。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先说一下,
这里是获取微信openId方法中的核心代码,并不是整个class类,只要你稍有耐心,跟着我的思路一起看一下,立马就会!

			//第一步:前端需要获取到用户同意授权的code给你传过来【code不用你管,拿String接收传来的参数即可】
			//url中的参数说明:
			//appId:不用解释,你懂得
			//appSecret: 不用解释,你懂得
			//code:前端传来的code
            String strURL = "https://api.weixin.qq.com/sns/jscode2session?appid="+appId+"&secret="+appSecret+"&js_code="+code+"&grant_type=authorization_code";
			//第二步:发起请求【copy就行了】
            try {
                URL url = new URL(strURL);// 创建连接
                HttpURLConnection connection = (HttpURLConnection) url.openConnection();
                connection.setDoOutput(true);
                connection.setDoInput(true);
                connection.setUseCaches(false);
                connection.setInstanceFollowRedirects(true);
                connection.setRequestMethod("POST"); // 设置请求方式
                connection.setRequestProperty("Accept", "application/json"); // 设置接收数据的格式
                connection.setRequestProperty("Content-Type", "application/json"); // 设置发送数据的格式
                //开始发送请求
                connection.connect();
                OutputStreamWriter out = new OutputStreamWriter(connection.getOutputStream(), "UTF-8"); // utf-8编码
                out.flush();
                out.close();
                int ResponseCode = connection.getResponseCode();
                InputStream is = null;
                if (ResponseCode == 200) {
                    is = connection.getInputStream();
                } else {
                    is = connection.getErrorStream();
                }
                // 第三步:读取响应
                ///在这里说一下,获取微信返回的方式有两种,随便挑一种即可
                //第一种:获取返回信息方式【比较骚气,用byte解析后获取】
                int length = (int) connection.getContentLength();// 获取长度
                if (length != -1) {
                    byte[] data = new byte[length];
                    byte[] temp = new byte[512];
                    int readLen = 0;
                    int destPos = 0;
                    while ((readLen = is.read(temp)) > 0) {
                        System.arraycopy(temp, 0, data, destPos, readLen);
                        destPos += readLen;
                    }
                    String result = new String(data, "UTF-8"); // utf-8编码
                    Map<String, Object> resultMap = com.alibaba.fastjson.JSONObject.parseObject(result);
                    //【这里是你获取到openId的逻辑判断】
                    //【plifeUser是我当时的用户实体类,保存openId,复制到你的项目可以删掉】
                    plifeUser.setOpenId((String) resultMap.get("openid"));
                }
                //第二种:获取返回信息方式【更简单一点吧,但是第一种更骚气点】
                /*String contentEncoding = connection.getContentEncoding();
                String body= IOUtils.toString(is, contentEncoding);
                System.out.println(body);
                org.json.JSONObject jsonObject=new org.json.JSONObject(body);
                String openId=jsonObject.getString("openid");
                //【这里是你获取到openId的逻辑判断】
                //【plifeUser是我当时的用户实体类,保存openId,复制到你的项目可以删掉】
                plifeUser.setOpenId(openId);*/
            } catch (IOException e) {
				//  LOG.error("Exception occur when send http post request!", e);
            }

好了,到此为止,微信小程序获取用户的OpenId就完成了,基板上你copy就行了。记得导包哦!!!!!!!!!

### Java环境下uni-app微信小程序获取用户手机号的方法 在Java环境中使用uni-app开发微信小程序获取用户的手机号涉及多个方面。具体来说,在前端部分,通过调用微信提供的接口实现授权登录以及请求用户手机号码;而在服务端,则需处理来自客户端的数据验证与存储。 #### 客户端(uni-app) 为了能够成功获取用户的手机号,应用程序需要先完成基础的登录操作[^2]: ```javascript // 登录函数定义 login() { let that = this; uni.login({ provider: 'weixin', success(res) { console.log('Login Success', res); // 将code发送给服务器换取openid等信息 that.getCode(); }, fail(err) { console.error('Login Failed', err); } }); } ``` 当应用已经获得了必要的权限之后,可以进一步尝试去取得用户的电话号码。这一步骤同样依赖于`wx.getPhoneNumber()` API 的调用: ```javascript getPhoneNumber(e){ if (!e.detail.errMsg || e.detail.errMsg !== "getPhoneNumber:ok") { wx.showToast({title:'您拒绝了提供手机号'}); return false; } else { const iv = e.detail.iv; const encryptedData = e.detail.encryptedData; // 发送加密数据至后台解密 uni.request({ url: `${this.serverUrl}/decryptPhone`, // 后台地址 method:"POST", data:{ code:this.code, iv:iv, encryptedData:encryptedData }, success:(res)=>{ console.log("Get Phone Number Result:",res.data.phoneNumber); } }) } } ``` 上述代码片段展示了如何捕获用户同意分享其手机号后的回调事件,并将获得的信息传递给后端进行下一步处理。 #### 服务端(Java) 对于Java编写的服务端而言,主要职责在于接收从前端传来的参数并对这些经过AES算法加密过的资料做解析工作。通常情况下会利用WeChat官方所提供的工具类或者第三方库来简化这个过程。下面给出了一段简单的Spring Boot风格的例子用于演示目的: ```java @RestController @RequestMapping("/api") public class WechatController { @PostMapping("/decryptPhone") public ResponseEntity<String> decryptPhone(@RequestBody Map<String, String> params) throws Exception{ WXBizMsgCrypt pc = new WXBizMsgCrypt(token, encodingAesKey, appid); String session_key = getSessionKey(params.get("code")); // 自行实现此方法以交换session key JSONObject json = JSON.parseObject(pc.decrypt(encryptedData,params.get("iv"),session_key)); return ResponseEntity.ok(json.getString("pureMsg")); } private String getSessionKey(String js_code){ RestTemplate restTemplate=new RestTemplate(); HttpHeaders headers = new HttpHeaders(); HttpEntity entity = new HttpEntity(headers); ResponseEntity<Map> response=restTemplate.exchange( "https://api.weixin.qq.com/sns/jscode2session?appid={APPID}&secret={SECRET}&js_code="+js_code+"&grant_type=authorization_code", HttpMethod.GET,entity,Map.class,"your_app_id","your_secret"); return (String)((LinkedHashMap)(response.getBody())).get("session_key"); } } ``` 这段程序说明了怎样设置一个RESTful Web Service 来接受来自uni-app的小程序请求,并执行相应的业务逻辑——即对接收到的数据实施解密动作从而得到真实的手机号码。 请注意以上仅为概念性的指导而非完整的解决方案,实际项目中还需要考虑更多的细节比如安全性保障措施、异常情况下的错误提示等等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值