有時候我們可能需要在其他的網(wǎng)頁上展示我們自己的小程序中某些頁面的小程序碼,這種時候,我們需要用到小程序的生成小程序碼的相關(guān)接口。
創(chuàng)新互聯(lián)專注于通州網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供通州營銷型網(wǎng)站建設(shè),通州網(wǎng)站制作、通州網(wǎng)頁設(shè)計、通州網(wǎng)站官網(wǎng)定制、小程序開發(fā)服務(wù),打造通州網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供通州網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
工具選型
我們?nèi)匀贿x用簡單方便的weixin-java-miniapp來完成此功能。
項目配置
詳見我們的另一篇文章點此進入
生成小程序碼的相關(guān)類型
小程序碼的其他生成方式以及相關(guān)類型在這篇文章點此進入中介紹的較為詳細,此處不再贅述,以下僅以生成不限制張數(shù)的這種類型來做一個示例。
生成小程序碼圖片
先獲取小程序的service實例wxMaService。
再獲取二維碼相關(guān)操作的service實例
// 獲取小程序服務(wù)實例 WxMaService wxMaService = WxMaConfiguration.getWxMaService(); // 獲取小程序二維碼生成實例 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ù)實例 WxMaService wxMaService = WxMaConfiguration.getWxMaService(); // 獲取小程序二維碼生成實例 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("生成小程序碼出錯", e); } // 設(shè)置contentType response.setContentType("image/png"); // 寫入response的輸出流中 OutputStream stream = response.getOutputStream(); stream.write(qrCodeBytes); stream.flush(); stream.close(); } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。