利用weixin-java-miniapp生成小程序碼并直接返回圖片文件流的方法
有時(shí)候我們可能需要在其他的網(wǎng)頁(yè)上展示我們自己的小程序中某些頁(yè)面的小程序碼,這種時(shí)候,我們需要用到小程序的生成小程序碼的相關(guān)接口。
工具選型
我們?nèi)匀贿x用簡(jiǎn)單方便的weixin-java-miniapp來(lái)完成此功能。
項(xiàng)目配置
詳見(jiàn)我們的另一篇文章點(diǎn)此進(jìn)入
生成小程序碼的相關(guān)類型
小程序碼的其他生成方式以及相關(guān)類型在這篇文章點(diǎn)此進(jìn)入中介紹的較為詳細(xì),此處不再贅述,以下僅以生成不限制張數(shù)的這種類型來(lái)做一個(gè)示例。
生成小程序碼圖片
先獲取小程序的service實(shí)例wxMaService。
再獲取二維碼相關(guān)操作的service實(shí)例
// 獲取小程序服務(wù)實(shí)例 WxMaService wxMaService = WxMaConfiguration.getWxMaService(); // 獲取小程序二維碼生成實(shí)例 WxMaQrcodeService wxMaQrcodeService = wxMaService.getQrcodeService(); // 設(shè)置小程序二維碼線條顏色為黑色 WxMaCodeLineColor lineColor = new WxMaCodeLineColor("0", "0", "0"); // 生成二維碼圖片字節(jié)流(此處也可以生成File類型,如果想將圖片文件保存到服務(wù)器就生成File類型,此處生成byte[]類型,方便直接返回文件流到前端) byte[] qrCodeBytes = null; qrCodeBytes = wxMaQrcodeService.createWxaCodeUnlimitBytes(String.valueOf(id), null, 430, false, lineColor, false);
返回文件流
將文件流寫(xiě)到response中,相關(guān)示例代碼如下:
@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{ // 獲取小程序服務(wù)實(shí)例 WxMaService wxMaService = WxMaConfiguration.getWxMaService(); // 獲取小程序二維碼生成實(shí)例 WxMaQrcodeService wxMaQrcodeService = wxMaService.getQrcodeService(); // 設(shè)置小程序二維碼線條顏色為黑色 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("生成小程序碼出錯(cuò)", e); } // 設(shè)置contentType response.setContentType("image/png"); // 寫(xiě)入response的輸出流中 OutputStream stream = response.getOutputStream(); stream.write(qrCodeBytes); stream.flush(); stream.close(); } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JS字符串false轉(zhuǎn)boolean的方法(推薦)
下面小編就為大家?guī)?lái)一篇JS字符串false轉(zhuǎn)boolean的方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03使用Chrome調(diào)試JavaScript的斷點(diǎn)設(shè)置和調(diào)試技巧
這篇文章主要介紹了使用Chrome調(diào)試JavaScript的斷點(diǎn)設(shè)置和調(diào)試技巧,需要的朋友可以參考下2014-12-12BootstrapTable+KnockoutJS自定義T4模板快速生成增刪改查頁(yè)面
這篇文章主要介紹了BootstrapTable+KnockoutJS自定義T4模板快速生成增刪改查頁(yè)面 的相關(guān)資料,需要的朋友可以參考下2016-08-08點(diǎn)擊頁(yè)面任何位置隱藏div的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇點(diǎn)擊頁(yè)面任何位置隱藏div的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09淺析微信小程序自定義日歷組件及flex布局最后一行對(duì)齊問(wèn)題
這篇文章主要介紹了微信小程序自定義日歷組件及flex布局最后一行對(duì)齊問(wèn)題,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10javascript創(chuàng)建動(dòng)態(tài)表單的方法
這篇文章主要介紹了javascript創(chuàng)建動(dòng)態(tài)表單的方法,實(shí)例分析了javascript動(dòng)態(tài)操作頁(yè)面表單元素的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07JavaScript實(shí)現(xiàn)上下浮動(dòng)的窗口效果代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)上下浮動(dòng)的窗口效果代碼,可實(shí)現(xiàn)自定義窗口在垂直方向上彈性移動(dòng)的效果,代碼備有完整的注釋說(shuō)明供讀者參考學(xué)習(xí),需要的朋友可以參考下2015-10-10