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

