本文介紹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)該對比明顯,如常見的黑白
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ū)別就是這一句,輸出到輸出流中,如果第三個參數(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:誤差校正等級,L = ~7% correction、M = ~15% correction、Q = ~25% correction、H = ~30% correction
//不設(shè)置時,默認(rèn)為 L 等級,等級不一樣,生成的圖案不同,但掃描的結(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;
}
}
測試代碼
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)封裝好了一個生成二維碼的工具類,但他同樣依賴于google提供的生成二維碼的依賴包。
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.12</version>
</dependency>
測試代碼
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í)都是對服務(wù)器有壓力的做法,所以一般情況下我覺得將二維碼的內(nèi)容傳遞給前端,交給前端生成比較好,降低服務(wù)器壓力,減小傳輸成本。
不過,如果二維碼內(nèi)容信息敏感,比如用戶的關(guān)鍵數(shù)據(jù),支付信息,支付憑證,密鑰之類的,則不應(yīng)該傳遞給前端生成。
致謝
Java生成二維碼的幾種實(shí)現(xiàn)方式(基于Spring Boot)
com.google.zxing 二維碼生成與解析文章來源:http://www.zghlxwxcb.cn/news/detail-464285.html
對你有幫助嗎?點(diǎn)個贊把~文章來源地址http://www.zghlxwxcb.cn/news/detail-464285.html
到了這里,關(guān)于Java生成二維碼的兩種方法的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!