Java生成二維碼的2種實(shí)現(xiàn)方法
前言
本文介紹Java生成二維碼的兩種方法,這兩種方法都依賴(lài)于google提供的二維碼依賴(lài)包。
一種是自己寫(xiě)工具類(lèi),代碼可以網(wǎng)上抄。
另一種是使用hutool第三方工具類(lèi)的依賴(lài)包,不用自己抄代碼。
一、自定義工具類(lèi)
自定義工具包就是借助google生成二維碼的依賴(lài)包,然后自己寫(xiě)工具類(lèi)。
<!-- 生成二維碼核心組件 --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>core</artifactId> <version>3.4.1</version> </dependency> <!-- 非web應(yīng)用無(wú)需導(dǎo)入javase依賴(lài)包 --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.4.1</version> </dependency>
工具類(lèi)
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)制表示,和前端頁(yè)面 CSS 的取色是一樣的,注意前后景顏色應(yīng)該對(duì)比明顯,如常見(jiàn)的黑白
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()) {
//二維碼圖片存在目錄不存在,開(kāi)始創(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)頁(yè)上進(jìn)行顯示,輸出到網(wǎng)頁(yè)與輸出到磁盤(pán)上的文件中,區(qū)別在于最后一句 ImageIO.write
* write(RenderedImage im,String formatName,File output):寫(xiě)到文件中
* 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:編碼提示類(lèi)型,枚舉類(lèi)型
Map<EncodeHintType, Object> hints = new HashMap();
//EncodeHintType.CHARACTER_SET:設(shè)置字符編碼類(lèi)型
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");
}
}二、使用第三方工具類(lèi)
hutool-all依賴(lài)包已經(jīng)封裝好了一個(gè)生成二維碼的工具類(lèi),但他同樣依賴(lài)于google提供的生成二維碼的依賴(lài)包。
<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ù)器有壓力的做法,所以一般情況下我覺(jué)得將二維碼的內(nèi)容傳遞給前端,交給前端生成比較好,降低服務(wù)器壓力,減小傳輸成本。
不過(guò),如果二維碼內(nèi)容信息敏感,比如用戶(hù)的關(guān)鍵數(shù)據(jù),支付信息,支付憑證,密鑰之類(lèi)的,則不應(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)過(guò)程詳解
這篇文章主要介紹了Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
springboot攔截器無(wú)法注入redisTemplate的解決方法
在工作中我們經(jīng)常需要做登錄攔截驗(yàn)證或者其他攔截認(rèn)證功能,但是在寫(xiě)攔截器的時(shí)候發(fā)現(xiàn)redisTemplate一直無(wú)法注入進(jìn)來(lái),本文就詳細(xì)的介紹了解決方法,感興趣的可以了解一下2021-06-06
Java工具類(lèi)BeanUtils庫(kù)介紹及實(shí)例詳解
這篇文章主要介紹了Java工具類(lèi)BeanUtils庫(kù)介紹及實(shí)例詳解,需要的朋友可以參考下2020-02-02
idea tomcat亂碼問(wèn)題的解決及相關(guān)設(shè)置的步驟
這篇文章主要介紹了idea tomcat亂碼問(wèn)題的解決及相關(guān)設(shè)置的步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
Spring?Boot中的過(guò)濾器攔截器監(jiān)聽(tīng)器使用技巧匯總
本文將介紹在Spring?Boot應(yīng)用程序中使用過(guò)濾器、攔截器和監(jiān)聽(tīng)器的使用技巧,我們將討論它們之間的區(qū)別,以及何時(shí)使用它們,我們還將提供代碼示例,以幫助您在自己的應(yīng)用程序中使用它們2023-12-12
Java設(shè)計(jì)模式之狀態(tài)模式State Pattern詳解
這篇文章主要介紹了Java設(shè)計(jì)模式之狀態(tài)模式State Pattern,狀態(tài)模式允許一個(gè)對(duì)象在其內(nèi)部狀態(tài)改變的時(shí)候改變其行為。這個(gè)對(duì)象看上去就像是改變了它的類(lèi)一樣2022-11-11

