利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法
有時候我們可能需要在其他的網(wǎng)頁上展示我們自己的小程序中某些頁面的小程序碼,這種時候,我們需要用到小程序的生成小程序碼的相關接口。
工具選型
我們仍然選用簡單方便的weixin-java-miniapp來完成此功能。
項目配置
詳見我們的另一篇文章點此進入
生成小程序碼的相關類型
小程序碼的其他生成方式以及相關類型在這篇文章點此進入中介紹的較為詳細,此處不再贅述,以下僅以生成不限制張數(shù)的這種類型來做一個示例。
生成小程序碼圖片
先獲取小程序的service實例wxMaService。
再獲取二維碼相關操作的service實例
// 獲取小程序服務實例 WxMaService wxMaService = WxMaConfiguration.getWxMaService(); // 獲取小程序二維碼生成實例 WxMaQrcodeService wxMaQrcodeService = wxMaService.getQrcodeService(); // 設置小程序二維碼線條顏色為黑色 WxMaCodeLineColor lineColor = new WxMaCodeLineColor("0", "0", "0"); // 生成二維碼圖片字節(jié)流(此處也可以生成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"); // 生成二維碼圖片字節(jié)流 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(); } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
使用Chrome調試JavaScript的斷點設置和調試技巧
這篇文章主要介紹了使用Chrome調試JavaScript的斷點設置和調試技巧,需要的朋友可以參考下2014-12-12BootstrapTable+KnockoutJS自定義T4模板快速生成增刪改查頁面
這篇文章主要介紹了BootstrapTable+KnockoutJS自定義T4模板快速生成增刪改查頁面 的相關資料,需要的朋友可以參考下2016-08-08javascript創(chuàng)建動態(tài)表單的方法
這篇文章主要介紹了javascript創(chuàng)建動態(tài)表單的方法,實例分析了javascript動態(tài)操作頁面表單元素的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07