利用weixin-java-miniapp生成小程序码并直接返回图片文件流的方法


Posted in Javascript onMarch 29, 2019

有时候我们可能需要在其他的网页上展示我们自己的小程序中某些页面的小程序码,这种时候,我们需要用到小程序的生成小程序码的相关接口。

工具选型

我们仍然选用简单方便的weixin-java-miniapp来完成此功能。

项目配置

详见我们的另一篇文章点此进入

生成小程序码的相关类型

小程序码的其他生成方式以及相关类型在这篇文章点此进入中介绍的较为详细,此处不再赘述,以下仅以生成不限制张数的这种类型来做一个示例。

生成小程序码图片

先获取小程序的service实例wxMaService。

再获取二维码相关操作的service实例

// 获取小程序服务实例
WxMaService wxMaService = WxMaConfiguration.getWxMaService();

// 获取小程序二维码生成实例
WxMaQrcodeService wxMaQrcodeService = wxMaService.getQrcodeService();

// 设置小程序二维码线条颜色为黑色
WxMaCodeLineColor lineColor = new WxMaCodeLineColor("0", "0", "0");

// 生成二维码图片字节流(此处也可以生成File类型,如果想将图片文件保存到服务器就生成File类型,此处生成byte[]类型,方便直接返回文件流到前端)
byte[] qrCodeBytes = null;
qrCodeBytes = wxMaQrcodeService.createWxaCodeUnlimitBytes(String.valueOf(id), null, 430, false, lineColor, false);

返回文件流

将文件流写到response中,相关示例代码如下:

@RestController
@RequestMapping("/qrCode")
public class QrCodeController {
 private static final Logger logger = LoggerFactory.getLogger(QrCodeController.class);

 @GetMapping("/getMiniappQrCode/{id}")
 public void getMiniappQrCode(@PathVariable("id") Long id, HttpServletRequest request, HttpServletResponse response) throws Exception{
  // 获取小程序服务实例
  WxMaService wxMaService = WxMaConfiguration.getWxMaService();
  // 获取小程序二维码生成实例
  WxMaQrcodeService wxMaQrcodeService = wxMaService.getQrcodeService();

  // 设置小程序二维码线条颜色为黑色
  WxMaCodeLineColor lineColor = new WxMaCodeLineColor("0", "0", "0");

  // 生成二维码图片字节流
  byte[] qrCodeBytes = null;
  try{
   qrCodeBytes = wxMaQrcodeService.createWxaCodeUnlimitBytes(String.valueOf(id), null, 430, false, lineColor, false);
  } catch(Exception e){
   logger.error("生成小程序码出错", e);
  }

  // 设置contentType
  response.setContentType("image/png");

  // 写入response的输出流中
  OutputStream stream = response.getOutputStream();
  stream.write(qrCodeBytes);
  stream.flush();
  stream.close();
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Jquery常用技巧收集整理篇
Nov 14 Javascript
js获取多个tagname的节点数组
Sep 22 Javascript
jQuery取id有.的值的方法
May 21 Javascript
JS函数的几种定义方式分析
Dec 17 Javascript
Javascript基于对象三大特性(封装性、继承性、多态性)
Jan 04 Javascript
angularjs指令之绑定策略(@、=、&)
Apr 13 Javascript
vue打包后显示空白正确处理方法
Nov 01 Javascript
使用vuex的state状态对象的5种方式
Apr 19 Javascript
基于Vue实现图片在指定区域内移动的思路详解
Nov 11 Javascript
vue实现表单未编辑或未保存离开弹窗提示功能
Apr 08 Javascript
如何利用Node.js与JSON搭建简单的动态服务器
Jun 16 Javascript
微信小程序实现底部弹出模态框
Nov 18 Javascript
微信小程序实现获取小程序码和二维码java接口开发
Mar 29 #Javascript
详解vue项目打包步骤
Mar 29 #Javascript
jQuery实现动态添加和删除input框代码实例
Mar 29 #jQuery
Vue项目history模式下微信分享爬坑总结
Mar 29 #Javascript
vue中使用微信公众号js-sdk踩坑记录
Mar 29 #Javascript
微信小程序学习笔记之本地数据缓存功能详解
Mar 29 #Javascript
微信JS-SDK updateAppMessageShareData安卓不能自定义分享详解
Mar 29 #Javascript
You might like
php字符串截取问题
2006/11/28 PHP
PHP连接access数据库
2008/03/27 PHP
PHPMailer安装方法及简单实例
2008/11/25 PHP
PHP基于php_imagick_st-Q8.dll实现JPG合成GIF图片的方法
2014/07/11 PHP
ThinkPHP3.2.2实现持久登录(记住我)功能的方法
2016/05/16 PHP
Laravel使用原生sql语句并调用的方法
2019/10/09 PHP
PhpStorm 2020.3:新增开箱即用的PHP 8属性(推荐)
2020/10/30 PHP
通用JS事件写法实现代码
2009/01/07 Javascript
Jquery中使用setInterval和setTimeout的方法
2013/04/08 Javascript
JS 实现导航栏悬停效果(续)
2013/09/24 Javascript
深入理解JavaScript是如何实现继承的
2013/12/12 Javascript
基于jQuery实现文本框只能输入数字(小数、整数)
2016/01/14 Javascript
BootStrap glyphicons 字体图标实现方法
2016/05/01 Javascript
用JS中split方法实现彩色文字背景效果实例
2016/08/24 Javascript
js 索引下标之li集合绑定点击事件
2018/01/12 Javascript
详解关于vue-area-linkage走过的坑
2018/06/27 Javascript
vue-router 源码之实现一个简单的 vue-router
2018/07/02 Javascript
jquery拖拽自动排序插件使用方法详解
2020/07/20 jQuery
JS删除String里某个字符的方法
2021/01/06 Javascript
Vue组件跨层级获取组件操作
2020/07/27 Javascript
JavaScript中如何调用Java方法
2020/09/16 Javascript
[01:30:54]《加油DOTA》 第三期
2014/08/18 DOTA
python解决方案:WindowsError: [Error 2]
2016/08/28 Python
python opencv 直方图反向投影的方法
2018/02/24 Python
Pycharm导入Python包,模块的图文教程
2018/06/13 Python
python实现给scatter设置颜色渐变条colorbar的方法
2018/12/13 Python
如何用Python制作微信好友个性签名词云图
2019/06/28 Python
python3.7将代码打包成exe程序并添加图标的方法
2019/10/11 Python
wxPython实现列表增删改查功能
2019/11/19 Python
Python 读取有公式cell的结果内容实例方法
2020/02/17 Python
python如何快速生成时间戳
2020/07/21 Python
在终端启动Python时报错的解决方案
2020/11/20 Python
localStorage 设置过期时间的方法实现
2018/12/21 HTML / CSS
买房子个人收入证明
2014/10/12 职场文书
ztree+ajax实现文件树下载功能
2021/05/18 Javascript
纯html+css实现Element loading效果
2021/08/02 HTML / CSS