溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何基于SpringBoot生成二維碼

發(fā)布時間:2022-03-31 14:43:51 來源:億速云 閱讀:658 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)如何基于SpringBoot生成二維碼的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

一、基于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 進(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);
 
            log.info("二維碼圖片生成成功:" + 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);
 
            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è)置時,默認(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;
    }
}

 上述代碼有點多,諸位可以在文末提供的下載地址將其下載下來,并用IDEA等開發(fā)工具將其打開,幾乎每行代碼debug都做了必要的注釋,在這里就不贅述了!

 總的來說,上面代碼主要包含了兩個部分,一部分是將實現(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;
}
}

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

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

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

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

 下面,debug換一種實現(xiàn)方式,采用目前比較知名、流行的開源工具Hutool加以實現(xiàn),同樣的道理需要在pom.xml中加入相應(yīng)的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控制器類中進(jìn)行調(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);
    }
}

通過瀏覽器訪問測試:

如何基于SpringBoot生成二維碼

感謝各位的閱讀!關(guān)于“如何基于SpringBoot生成二維碼”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI