Java生成二維碼的2種實(shí)現(xiàn)方法
前言
本文介紹Java生成二維碼的兩種方法,這兩種方法都依賴于google提供的二維碼依賴包。
一種是自己寫工具類,代碼可以網(wǎng)上抄。
另一種是使用hutool第三方工具類的依賴包,不用自己抄代碼。
一、自定義工具類
自定義工具包就是借助google生成二維碼的依賴包,然后自己寫工具類。
<!-- 生成二維碼核心組件 --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>core</artifactId> <version>3.4.1</version> </dependency> <!-- 非web應(yīng)用無需導(dǎo)入javase依賴包 --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.4.1</version> </dependency>
工具類
public class MyQrCodeUtil { //CODE_WIDTH:二維碼寬度,單位像素 private static final int CODE_WIDTH = 400; //CODE_HEIGHT:二維碼高度,單位像素 private static final int CODE_HEIGHT = 400; //FRONT_COLOR:二維碼前景色,0x000000 表示黑色 private static final int FRONT_COLOR = 0x000000; //BACKGROUND_COLOR:二維碼背景色,0xFFFFFF 表示白色 //演示用 16 進(jìn)制表示,和前端頁面 CSS 的取色是一樣的,注意前后景顏色應(yīng)該對(duì)比明顯,如常見的黑白 private static final int BACKGROUND_COLOR = 0xFFFFFF; public static void createCodeToFile(String content, File codeImgFileSaveDir, String fileName) { try { if (StringUtils.isBlank(content) || StringUtils.isBlank(fileName)) { return; } content = content.trim(); if (codeImgFileSaveDir==null || codeImgFileSaveDir.isFile()) { //二維碼圖片存在目錄為空,默認(rèn)放在桌面... codeImgFileSaveDir = FileSystemView.getFileSystemView().getHomeDirectory(); } if (!codeImgFileSaveDir.exists()) { //二維碼圖片存在目錄不存在,開始創(chuàng)建... codeImgFileSaveDir.mkdirs(); } //核心代碼-生成二維碼 BufferedImage bufferedImage = getBufferedImage(content); File codeImgFile = new File(codeImgFileSaveDir, fileName); ImageIO.write(bufferedImage, "png", codeImgFile); System.out.println("二維碼圖片生成成功:" + codeImgFile.getPath()); } catch (Exception e) { e.printStackTrace(); } } /** * 生成二維碼并輸出到輸出流, 通常用于輸出到網(wǎng)頁上進(jìn)行顯示,輸出到網(wǎng)頁與輸出到磁盤上的文件中,區(qū)別在于最后一句 ImageIO.write * write(RenderedImage im,String formatName,File output):寫到文件中 * write(RenderedImage im,String formatName,OutputStream output):輸出到輸出流中 * @param content :二維碼內(nèi)容 * @param outputStream :輸出流,比如 HttpServletResponse 的 getOutputStream */ public static void createCodeToOutputStream(String content, OutputStream outputStream) { try { if (StringUtils.isBlank(content)) { return; } content = content.trim(); //核心代碼-生成二維碼 BufferedImage bufferedImage = getBufferedImage(content); //區(qū)別就是這一句,輸出到輸出流中,如果第三個(gè)參數(shù)是 File,則輸出到文件中 ImageIO.write(bufferedImage, "png", outputStream); System.out.println("二維碼圖片生成到輸出流成功..."); } catch (Exception e) { e.printStackTrace(); } } //核心代碼-生成二維碼 private static BufferedImage getBufferedImage(String content) throws WriterException { //com.google.zxing.EncodeHintType:編碼提示類型,枚舉類型 Map<EncodeHintType, Object> hints = new HashMap(); //EncodeHintType.CHARACTER_SET:設(shè)置字符編碼類型 hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); //EncodeHintType.ERROR_CORRECTION:設(shè)置誤差校正 //ErrorCorrectionLevel:誤差校正等級(jí),L = ~7% correction、M = ~15% correction、Q = ~25% correction、H = ~30% correction //不設(shè)置時(shí),默認(rèn)為 L 等級(jí),等級(jí)不一樣,生成的圖案不同,但掃描的結(jié)果是一樣的 hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.M); //EncodeHintType.MARGIN:設(shè)置二維碼邊距,單位像素,值越小,二維碼距離四周越近 hints.put(EncodeHintType.MARGIN, 1); MultiFormatWriter multiFormatWriter = new MultiFormatWriter(); BitMatrix bitMatrix = multiFormatWriter.encode(content, BarcodeFormat.QR_CODE, CODE_WIDTH, CODE_HEIGHT, hints); BufferedImage bufferedImage = new BufferedImage(CODE_WIDTH, CODE_HEIGHT, BufferedImage.TYPE_INT_BGR); for (int x = 0; x < CODE_WIDTH; x++) { for (int y = 0; y < CODE_HEIGHT; y++) { bufferedImage.setRGB(x, y, bitMatrix.get(x, y) ? FRONT_COLOR : BACKGROUND_COLOR); } } return bufferedImage; } }
測(cè)試代碼
public class App { public static void main( String[] args ) { //使用自定義工具包生成二維碼 File myUtilFileDir = new File("E:\\files"); MyQrCodeUtil.createCodeToFile("123",myUtilFileDir,"qrcode1.png"); } }
二、使用第三方工具類
hutool-all依賴包已經(jīng)封裝好了一個(gè)生成二維碼的工具類,但他同樣依賴于google提供的生成二維碼的依賴包。
<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>5.8.12</version> </dependency>
測(cè)試代碼
public class App { public static void main( String[] args ) { System.out.println( "Hello World!" ); //使用自定義工具包生成二維碼 File myUtilFileDir = new File("E:\\files"); MyQrCodeUtil.createCodeToFile("123",myUtilFileDir,"qrcode1.png"); //使用hutool工具包生成二維碼 File hutoolFile = new File("E:\\files\\qrcode2.png"); QrConfig qrConfig = QrConfig.create(); qrConfig.setBackColor(Color.WHITE); qrConfig.setForeColor(Color.BLACK); QrCodeUtil.generate("123", qrConfig,hutoolFile); } }
關(guān)于生成二維碼的一些討論
前端生成二維碼還是后端生成二維碼
在后端生成二維碼,和傳送二維碼給前端其實(shí)都是對(duì)服務(wù)器有壓力的做法,所以一般情況下我覺得將二維碼的內(nèi)容傳遞給前端,交給前端生成比較好,降低服務(wù)器壓力,減小傳輸成本。
不過,如果二維碼內(nèi)容信息敏感,比如用戶的關(guān)鍵數(shù)據(jù),支付信息,支付憑證,密鑰之類的,則不應(yīng)該傳遞給前端生成。
致謝
總結(jié)
到此這篇關(guān)于Java生成二維碼的2種實(shí)現(xiàn)方法的文章就介紹到這了,更多相關(guān)Java生成二維碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解
這篇文章主要介紹了Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11springboot攔截器無法注入redisTemplate的解決方法
在工作中我們經(jīng)常需要做登錄攔截驗(yàn)證或者其他攔截認(rèn)證功能,但是在寫攔截器的時(shí)候發(fā)現(xiàn)redisTemplate一直無法注入進(jìn)來,本文就詳細(xì)的介紹了解決方法,感興趣的可以了解一下2021-06-06Java工具類BeanUtils庫(kù)介紹及實(shí)例詳解
這篇文章主要介紹了Java工具類BeanUtils庫(kù)介紹及實(shí)例詳解,需要的朋友可以參考下2020-02-02idea tomcat亂碼問題的解決及相關(guān)設(shè)置的步驟
這篇文章主要介紹了idea tomcat亂碼問題的解決及相關(guān)設(shè)置的步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11Spring?Boot中的過濾器攔截器監(jiān)聽器使用技巧匯總
本文將介紹在Spring?Boot應(yīng)用程序中使用過濾器、攔截器和監(jiān)聽器的使用技巧,我們將討論它們之間的區(qū)別,以及何時(shí)使用它們,我們還將提供代碼示例,以幫助您在自己的應(yīng)用程序中使用它們2023-12-12Java設(shè)計(jì)模式之狀態(tài)模式State Pattern詳解
這篇文章主要介紹了Java設(shè)計(jì)模式之狀態(tài)模式State Pattern,狀態(tài)模式允許一個(gè)對(duì)象在其內(nèi)部狀態(tài)改變的時(shí)候改變其行為。這個(gè)對(duì)象看上去就像是改變了它的類一樣2022-11-11