欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java生成二維碼的兩種實現(xiàn)方式(基于Spring?Boot)

 更新時間:2023年07月13日 10:49:40   作者:Love?is?beautiful  
這篇文章主要給大家介紹了關(guān)于Java生成二維碼的兩種實現(xiàn)方式,文中的代碼基于Spring?Boot,本文基于JAVA環(huán)境,以SpringBoot框架為基礎(chǔ)開發(fā),文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

前言

本文將基于Spring Boot介紹兩種生成二維碼的實現(xiàn)方式,一種是基于Google開發(fā)工具包,另一種是基于Hutool來實現(xiàn);

為了方便理解二維碼的實際應用場景,舉一些例子!

(1)進銷存系統(tǒng) 想必大家都聽說過,其系統(tǒng)中的商品二維碼承載了許多重要、核心的關(guān)鍵信息,比如商品編碼、商品名稱、規(guī)格、型號、單位、作用/使用說明等信息;操作者可以借助硬件設(shè)備,如“掃碼槍”,通過掃描該二維碼后將該商品錄入到商品庫中;

(2)再比如溯源系統(tǒng)中的產(chǎn)品,用戶可以通過微信等APP中的掃一掃,掃描貼在產(chǎn)品上的二維碼,不出片刻即可得到該產(chǎn)品的相關(guān)信息,比如產(chǎn)品名稱、生源地、簡介、價格、生產(chǎn)環(huán)境、經(jīng)手人等信息;

 下面我們將基于Spring Boot,并采用兩種方式實現(xiàn)二維碼的生成,對于每一種方式還提供兩種類型的二維碼返回形式,即:物理文件 和 圖片響應流

一、基于Google開發(fā)工具包ZXing生成二維碼

(1)首先,需要在pom.xml依賴配置文件中加入該工具包的依賴Jar,如下所示:   

<!-- zxing生成二維碼 -->
<dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>core</artifactId>
    <version>3.3.3</version>
</dependency>
<dependency>
    <groupId>com.google.zxing</groupId>
    <artifactId>javase</artifactId>
    <version>3.3.3</version>
</dependency>

(2)然后,建立一二維碼處理工具類QRCodeUtil,其核心代碼如下所示:

/**
 * 二維碼工具
 * @Author:debug (SteadyJack)
 * @Link: weixin-> debug0868  qq-> 1948831260
 * @Date: 2020/11/16 22:38
 **/
public class QRCodeUtil {
    private static final Logger log= LoggerFactory.getLogger(QRCodeUtil.class);
    //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 進制表示,和前端頁面 CSS 的取色是一樣的,注意前后景顏色應該對比明顯,如常見的黑白
    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()) {
                //二維碼圖片存在目錄為空,默認放在桌面...
                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);
            log.info("二維碼圖片生成成功:" + codeImgFile.getPath());
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    /**
     * 生成二維碼并輸出到輸出流, 通常用于輸出到網(wǎng)頁上進行顯示,輸出到網(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);
            log.info("二維碼圖片生成到輸出流成功...");
        } 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è)置時,默認為 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;
    }
}

總的來說,上面代碼主要包含了兩個部分,一部分是將實現(xiàn)如何將信息塞入二維碼并將其生成圖片存儲至物理文件目錄下;另一部分是實現(xiàn)如何直接將信息塞入二維碼并生成圖片最終以圖片流的形式將其返回給前端調(diào)用端;

(3)最后,我們需要新建一個QrCodeController控制器類,并在其中創(chuàng)建兩個請求方法,用于測試Google ZXing工具包這種方式生成兩種類型的二維碼是否可行,其代碼如下所示:

@RequestMapping("qr/code")
public class QrCodeController extends BaseController{
    private static final String RootPath="E:\\shFiles\\QRCode";
    private static final String FileFormat=".png";
    private static final ThreadLocal<SimpleDateFormat> LOCALDATEFORMAT=ThreadLocal.withInitial(() -> new SimpleDateFormat("yyyyMMddHHmmss"));
    //生成二維碼并將其存放于本地目錄
    @PostMapping("generate/v1")
    public BaseResponse generateV1(String content){
        BaseResponse response=new BaseResponse(StatusCode.Success);
        try {
            final String fileName=LOCALDATEFORMAT.get().format(new Date());
            QRCodeUtil.createCodeToFile(content,new File(RootPath),fileName+FileFormat);
        }catch (Exception e){
            response=new BaseResponse(StatusCode.Fail.getCode(),e.getMessage());
        }
        return response;
    }
    //生成二維碼并將其返回給前端調(diào)用者
    @PostMapping("generate/v2")
    public BaseResponse generateV2(String content,HttpServletResponse servletResponse){
        BaseResponse response=new BaseResponse(StatusCode.Success);
        try {
            QRCodeUtil.createCodeToOutputStream(content,servletResponse.getOutputStream());
        }catch (Exception e){
            response=new BaseResponse(StatusCode.Fail.getCode(),e.getMessage());
        }
        return response;
}
}

 最后是將該項目運行起來并采用Postman對該接口進行測試,首先是控制器第一個方法接口的測試,其測試結(jié)果如下圖所示(生成的二維碼圖片是存放在 E:\\shFiles\\QRCode 中的):

 最后是控制器第二個方法接口的測試,其測試結(jié)果如下圖所示:

PS:如果不想存儲二維碼圖片到實際的文件目錄,則可以采用“圖片流”的形式將其返回即可;反之,則可以將生成的二維碼圖片存儲起來并返回該圖片的訪問鏈接給到前端(這個就稍微有點麻煩了,既要存儲、又要賦予圖片的訪問域名和鏈接);具體取舍可以根據(jù)實際業(yè)務(wù)情況來做抉擇吧!

二、基于開源的Hutool工具生成二維碼

 下面,debug換一種實現(xiàn)方式,采用目前比較知名、流行的開源工具Hutool加以實現(xiàn),同樣的道理需要在pom.xml中加入相應的Jar依賴,如下所示:   

 <!--二維碼開發(fā)工具集-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>4.6.10</version>
        </dependency>
        <!-- zxing生成二維碼 -->
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>core</artifactId>
            <version>3.3.3</version>
        </dependency>
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>javase</artifactId>
            <version>3.3.3</version>
        </dependency>

然后,需要自定義一Java Config配置文件,以Bean的形式顯示配置并注入QrConfig,如下代碼所示:

package com.example.qrcode.Config;
 
import cn.hutool.extra.qrcode.QrConfig;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
 
import java.awt.*;
 
@Configuration
public class QRCode {
    @Bean
    public QrConfig qrConfig(){
        QrConfig qrConfig=new QrConfig();
        qrConfig.setBackColor(Color.white.getRGB());
        qrConfig.setForeColor(Color.black.getRGB());
        return qrConfig;
    }
}

緊接著我們建立一QRService,用于處理真正的生成二維碼的業(yè)務(wù)邏輯,其核心代碼如下所示:

package com.example.qrcode.Service;
 
import cn.hutool.extra.qrcode.QrCodeUtil;
import cn.hutool.extra.qrcode.QrConfig;
import com.example.qrcode.Config.QRCode;
import org.springframework.stereotype.Service;
import org.springframework.web.bind.annotation.RequestMapping;
 
import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;
import java.io.File;
import java.io.IOException;
 
@Service
public class QRService {
    @Resource
    QrConfig qrconig;
    public void generateFile(String content, File file){
        //生成到本地文件
        QrCodeUtil.generate(content, qrconig, file);
    }
    //輸出到流
    public void generateStream(String content, HttpServletResponse response) throws IOException {
        QrCodeUtil.generate(content,qrconig,"png",response.getOutputStream());
    }
}

 最終,是在QRController控制器類中進行調(diào)用,如下代碼所示:

package com.example.qrcode.Controller;
 
import com.example.qrcode.Service.QRService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
 
@RestController
public class QRController {
    @Autowired
    QRService qrService;
    @RequestMapping("123")
    public void generateV3(String content, HttpServletResponse servletResponse) throws IOException {
        qrService.generateStream(content,servletResponse);
    }
}

 通過瀏覽器訪問測試:

總結(jié) 

到此這篇關(guān)于Java生成二維碼的兩種實現(xiàn)方式的文章就介紹到這了,更多相關(guān)Spring Boot生成二維碼內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • mybatis如何使用xml中的if-else/choose

    mybatis如何使用xml中的if-else/choose

    最近需要使用xml文件來實現(xiàn)一些增刪改查,此文對其中的if-else 加以說明,使用 xml 怎么來使用和接收呢,下面小編給大家講解mybatis如何使用xml中的if-else/choose,感興趣的朋友一起看看吧
    2024-04-04
  • java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù)

    java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù)

    今天小編就為大家分享一篇java實現(xiàn)讀取txt文件并以在每行以空格取數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Spring源碼完美導入IDEA的過程

    Spring源碼完美導入IDEA的過程

    正值春節(jié)假期,小伙伴私信我idea導入spring源碼的過程,今天抽空給大家整理一篇教程幫助大家學習Spring源碼完美導入IDEA的詳細過程,感興趣的朋友一起看看吧
    2022-02-02
  • Maven之導入thymeleaf依賴飄紅問題及解決

    Maven之導入thymeleaf依賴飄紅問題及解決

    這篇文章主要介紹了Maven之導入thymeleaf依賴飄紅問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • Spring中的@Scheduled源碼解析

    Spring中的@Scheduled源碼解析

    這篇文章主要介紹了Spring中的@Scheduled源碼解析,定時任務(wù)調(diào)度的基礎(chǔ)是ScheduledAnnotationBeanPostProcessor類,這是一個實現(xiàn)了BeanPostProcessor接口的后置處理器,需要的朋友可以參考下
    2023-09-09
  • Jenkins+Git+Maven自動化部署配置詳解

    Jenkins+Git+Maven自動化部署配置詳解

    本文主要介紹了Jenkins+Git+Maven自動化部署配置詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-01-01
  • MyBatis中SQL片段復用使用方法詳解

    MyBatis中SQL片段復用使用方法詳解

    在使用 MyBatis 進行數(shù)據(jù)庫操作時,常常會遇到一些 SQL 語句的部分內(nèi)容重復出現(xiàn)的情況,比如多個查詢語句都涉及相同的字段列表,這時,MyBatis 的 SQL 片段復用功能就派上用場了,接下小編給大家介紹了MyBatis中SQL片段復用使用方法,需要的朋友可以參考下
    2024-12-12
  • Spring @Profile注解詳解

    Spring @Profile注解詳解

    這篇文章主要介紹了Spring @Profile注解詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • java實現(xiàn)簡單點贊功能

    java實現(xiàn)簡單點贊功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)簡單點贊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • java排序算法之_選擇排序(實例講解)

    java排序算法之_選擇排序(實例講解)

    下面小編就為大家?guī)硪黄猨ava排序算法之_選擇排序(實例講解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09

最新評論