java调用微信getWXACodeUnlimit()获取小程序码

小程序官方文档链接:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/qr-code/wxacode.getUnlimited.html

需要注意base64转换需要拼接:data:image/jpg;base64,

public String getWxCode(String accessToken) {
		String PROGRAM_CODE_URL=“https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=%s”;
        try {
            String url=String.format(PROGRAM_CODE_URL, accessToken);
        	RestTemplate rest = new RestTemplate();
        	Map<String,Object> param = new HashMap<>();
        	// 限制32位
            param.put("scene", “123456”));
            // 必须发布的页面,非必填
            param.put("page", "pages/index/index");
            param.put("width", 430);
            param.put("auto_color", false);
            Map<String,Object> line_color = new HashMap<>();
            line_color.put("r", 0);
            line_color.put("g", 0);
            line_color.put("b", 0);
            param.put("line_color", line_color);
            log.info("调用生成微信URL接口传参:" + param);
            MultiValueMap<String, String> headers = new LinkedMultiValueMap<>();
            HttpEntity requestEntity = new HttpEntity(param, headers);
            ResponseEntity<byte[]> entity = rest.exchange(url, HttpMethod.POST, requestEntity, byte[].class, new Object[0]);
            log.info("调用小程序生成微信永久小程序码URL接口返回结果:" + entity.getBody());
            byte[] result = entity.getBody();
            log.info(Base64.encodeBase64String(result));
            res=Base64.encodeBase64String(result);
            if(StringUtils.isNotBlank(res)) {
            	String encoded = "data:image/jpg;base64," + res.replaceAll("[\\s*\t\n\r]", "");
            	return encoded;
            }
            
        } catch (Exception e) {
            log.error("调用小程序生成二维码失败:{}", e);
            throw new BussnessException("调用小程序生成二维码失败");
        }
        return null;
    }
### 使用 Java 调用微信 API 生成小程序二维码 #### 准备工作 为了能够成功调用微信公众平台提供的接口来生成小程序二维码,需要先完成如下准备工作: - 注册并登录微信公众平台账号; - 创建小程序项目,并获得 `AppID` 和 `AppSecret`。 这些信息用于后续获取访问令牌(access token),这是发起任何微信开放平台 API 请求的前提条件[^1]。 #### 获取 Access Token Access Token 是调用微信 API 的凭证。可以通过向指定 URL 发送 GET 请求的方式得到它。URL 构造形式如下所示: ``` https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid={APPID}&secret={APPSECRET} ``` 其中 `{APPID}` 和 `{APPSECRET}` 需要替换为实际应用对应的 App ID 及密钥。返回的数据是一个 JSON 对象,里面包含了 access_token 字段以及有效期等其他字段。 ```json { "access_token":"ACCESS_TOKEN", "expires_in":7200 } ``` 此步骤可以封装成一个方法,在每次需要用到 access_token 前自动刷新或缓存起来以减少不必要的网络请求开销[^2]。 #### 生成小程序二维码 当拥有有效的 access_token 后,则可以根据需求选择不同的接口来创建不同类型的二维码。对于本案例而言,将采用无限量生成的小程序码接口。该接口允许开发者传入页面路径参数以及其他配置项来自定义最终呈现效果。 构建 HTTP POST 请求体时需要注意的是,所有传递给服务器端的数据都应当序列化成为 JSON 格式的字符串而不是表单数据。另外,某些样式属性比如颜色设置只适用于特定版本的小程序码,请参照官方说明文档确认适用范围[^3]。 下面给出一段完整的 Spring Boot 控制器层代码片段作为参考实现: ```java @PostMapping("/getQrcode") public AjaxResult getQrcode(@RequestBody WxCodeUnlimitedReqDTO wxCodeUnlimitedReqDTO){ log.info("===> 获取注册二维码 <==="); log.info(JSON.toJSONString(wxCodeUnlimitedReqDTO)); // 此处省略了获取AccessToken的具体逻辑 String url = "https://api.weixin.qq.com/wxa/getwxacodeunlimit?access_token=" + accessToken; HttpHeaders headers = new HttpHeaders(); headers.setContentType(MediaType.APPLICATION_JSON); HttpEntity<String> entity = new HttpEntity<>(JSON.toJSONString(wxCodeUnlimitedReqDTO), headers); ResponseEntity<byte[]> response = restTemplate.postForEntity(url, entity , byte[].class ); File file = new File("qrcode.png"); try (FileOutputStream fos = new FileOutputStream(file)) { fos.write(response.getBody()); } return R.ok().put("data",file.getAbsolutePath()); } ``` 上述代码展示了如何接收前端发送过来的请求参数并通过 RestTemplate 工具类执行远程调用来取得二进制流格式的结果文件。最后保存到本地磁盘并将存储位置反馈回去供客户端下载查看。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值