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

Java生成二維碼的2種實(shí)現(xiàn)方法

 更新時(shí)間:2023年07月13日 10:54:20   作者:笑我歸無處  
這篇文章主要給大家介紹了關(guān)于Java生成二維碼的2種實(shí)現(xiàn)方法,二維碼的實(shí)質(zhì)就是一個(gè)鏈接地址,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下

前言

本文介紹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)文章

  • java使用反射給對(duì)象屬性賦值的兩種方法

    java使用反射給對(duì)象屬性賦值的兩種方法

    JAVA反射機(jī)制是在運(yùn)行狀態(tài)中,對(duì)于任意一個(gè)類,都能夠知道這個(gè)類的所有屬性和方法,下面這篇文章主要給大家介紹了關(guān)于java使用反射給對(duì)象屬性賦值的兩種方法,需要的朋友可以參考下
    2023-04-04
  • Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解

    Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解

    這篇文章主要介紹了Kafka多節(jié)點(diǎn)分布式集群搭建實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • java并發(fā)之原子操作類和非阻塞算法

    java并發(fā)之原子操作類和非阻塞算法

    這篇文章主要為大家詳細(xì)介紹了java并發(fā)之原子操作類和非阻塞算法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • springboot攔截器無法注入redisTemplate的解決方法

    springboot攔截器無法注入redisTemplate的解決方法

    在工作中我們經(jīng)常需要做登錄攔截驗(yàn)證或者其他攔截認(rèn)證功能,但是在寫攔截器的時(shí)候發(fā)現(xiàn)redisTemplate一直無法注入進(jìn)來,本文就詳細(xì)的介紹了解決方法,感興趣的可以了解一下
    2021-06-06
  • 在lambda中使用外部變量的一些心得分享

    在lambda中使用外部變量的一些心得分享

    這篇文章主要介紹了在lambda中使用外部變量的一些心得,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Java工具類BeanUtils庫(kù)介紹及實(shí)例詳解

    Java工具類BeanUtils庫(kù)介紹及實(shí)例詳解

    這篇文章主要介紹了Java工具類BeanUtils庫(kù)介紹及實(shí)例詳解,需要的朋友可以參考下
    2020-02-02
  • idea tomcat亂碼問題的解決及相關(guān)設(shè)置的步驟

    idea tomcat亂碼問題的解決及相關(guān)設(shè)置的步驟

    這篇文章主要介紹了idea tomcat亂碼問題的解決及相關(guān)設(shè)置的步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • Spring?Boot中的過濾器攔截器監(jiān)聽器使用技巧匯總

    Spring?Boot中的過濾器攔截器監(jiān)聽器使用技巧匯總

    本文將介紹在Spring?Boot應(yīng)用程序中使用過濾器、攔截器和監(jiān)聽器的使用技巧,我們將討論它們之間的區(qū)別,以及何時(shí)使用它們,我們還將提供代碼示例,以幫助您在自己的應(yīng)用程序中使用它們
    2023-12-12
  • Java設(shè)計(jì)模式之狀態(tài)模式State Pattern詳解

    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ì)象看上去就像是改變了它的類一樣
    2022-11-11
  • JDK更換IDEA如何修改圖文詳解

    JDK更換IDEA如何修改圖文詳解

    這篇文章主要給大家介紹了關(guān)于JDK更換IDEA如何修改的相關(guān)資料,Java的不同版本的JDK之間存在細(xì)微的差別,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07

最新評(píng)論