java生成二維碼列印到瀏覽器(java生成二維碼列印到瀏覽器)

本文目錄一覽:

如何用java生成二維碼

package common;

import java.awt.Color;

import java.awt.Graphics2D;

import java.awt.Image;

import java.awt.image.BufferedImage;

import java.io.File;

import java.io.IOException;

import java.util.HashMap;

import java.util.Map;

import javax.imageio.ImageIO;

import jp.sourceforge.qrcode.QRCodeDecoder;

import jp.sourceforge.qrcode.exception.DecodingFailedException;

import com.google.zxing.BarcodeFormat;

import com.google.zxing.Binarizer;

import com.google.zxing.BinaryBitmap;

import com.google.zxing.EncodeHintType;

import com.google.zxing.LuminanceSource;

import com.google.zxing.MultiFormatReader;

import com.google.zxing.MultiFormatWriter;

import com.google.zxing.NotFoundException;

import com.google.zxing.WriterException;

import com.google.zxing.common.BitMatrix;

import com.google.zxing.common.HybridBinarizer;

import com.swetake.util.Qrcode;

/**

 * 二維碼生成工具類

 * @author Cloud

 * @data   2016-12-15

 * QRCode

 */

public class QRCodeUtil {

    

    //二維碼顏色

    private static final int BLACK = 0xFF000000;

    //二維碼顏色

    private static final int WHITE = 0xFFFFFFFF;

    /**

     * span style=”font-size:18px;font-weight:blod;”ZXing 方式生成二維碼/span

     * @param text    a href=”javascript:void();”二維碼內容/a

     * @param width    二維碼寬

     * @param height    二維碼高

     * @param outPutPath    二維碼生成保存路徑

     * @param imageType        二維碼生成格式

     */

    public static void zxingCodeCreate(String text, int width, int height, String outPutPath, String imageType){

        MapEncodeHintType, String his = new HashMapEncodeHintType, String();

        //設置編碼字符集

        his.put(EncodeHintType.CHARACTER_SET, “utf-8”);

        try {

            //1、生成二維碼

            BitMatrix encode = new MultiFormatWriter().encode(text, BarcodeFormat.QR_CODE, width, height, his);

            

            //2、獲取二維碼寬高

            int codeWidth = encode.getWidth();

            int codeHeight = encode.getHeight();

            

            //3、將二維碼放入緩衝流

            BufferedImage image = new BufferedImage(codeWidth, codeHeight, BufferedImage.TYPE_INT_RGB);

            for (int i = 0; i  codeWidth; i++) {

                for (int j = 0; j  codeHeight; j++) {

                    //4、循環將二維碼內容定入圖片

                    image.setRGB(i, j, encode.get(i, j) ? BLACK : WHITE);

                }

            }

            File outPutImage = new File(outPutPath);

            //如果圖片不存在創建圖片

            if(!outPutImage.exists())

                outPutImage.createNewFile();

            //5、將二維碼寫入圖片

            ImageIO.write(image, imageType, outPutImage);

        } catch (WriterException e) {

            e.printStackTrace();

            System.out.println(“二維碼生成失敗”);

        } catch (IOException e) {

            e.printStackTrace();

            System.out.println(“生成二維碼圖片失敗”);

        }

    }

    

    /**

     * span style=”font-size:18px;font-weight:blod;”二維碼解析/span

     * @param analyzePath    二維碼路徑

     * @return

     * @throws IOException

     */

    @SuppressWarnings({ “rawtypes”, “unchecked” })

    public static Object zxingCodeAnalyze(String analyzePath) throws Exception{

        MultiFormatReader formatReader = new MultiFormatReader();

        Object result = null;

        try {

            File file = new File(analyzePath);

            if (!file.exists())

            {

                return “二維碼不存在”;

            }

            BufferedImage image = ImageIO.read(file);

            LuminanceSource source = new LuminanceSourceUtil(image);

            Binarizer binarizer = new HybridBinarizer(source);  

            BinaryBitmap binaryBitmap = new BinaryBitmap(binarizer);

            Map hints = new HashMap();

            hints.put(EncodeHintType.CHARACTER_SET, “UTF-8”);

            result = formatReader.decode(binaryBitmap, hints);

        } catch (NotFoundException e) {

            e.printStackTrace();

        }  

        return result;

    }

    

    /**

     * span style=”font-size:18px;font-weight:blod;”QRCode 方式生成二維碼/span

     * @param content    二維碼內容

     * @param imgPath    二維碼生成路徑

     * @param version    二維碼版本

     * @param isFlag    是否生成Logo圖片    為NULL不生成

     */

    public static void QRCodeCreate(String content, String imgPath, int version, String logoPath){

         try {  

            Qrcode qrcodeHandler = new Qrcode();  

            //設置二維碼排錯率,可選L(7%) M(15%) Q(25%) H(30%),排錯率越高可存儲的信息越少,但對二維碼清晰度的要求越小    

            qrcodeHandler.setQrcodeErrorCorrect(‘M’);  

            //N代表數字,A代表字元a-Z,B代表其他字元  

            qrcodeHandler.setQrcodeEncodeMode(‘B’);  

            //版本1為21*21矩陣,版本每增1,二維碼的兩個邊長都增4;所以版本7為45*45的矩陣;最高版本為是40,是177*177的矩陣  

            qrcodeHandler.setQrcodeVersion(version);

            //根據版本計算尺寸

            int imgSize = 67 + 12 * (version – 1) ;  

            byte[] contentBytes = content.getBytes(“gb2312”);  

            BufferedImage bufImg = new BufferedImage(imgSize , imgSize ,BufferedImage.TYPE_INT_RGB);  

            Graphics2D gs = bufImg.createGraphics();  

            gs.setBackground(Color.WHITE);  

            gs.clearRect(0, 0, imgSize , imgSize);  

            // 設定圖像顏色  BLACK

            gs.setColor(Color.BLACK);

            // 設置偏移量 不設置可能導致解析出錯  

            int pixoff = 2;

            // 輸出內容  二維碼  

            if (contentBytes.length  0  contentBytes.length  130) {

                boolean[][] codeOut = qrcodeHandler.calQrcode(contentBytes);

                for (int i = 0; i  codeOut.length; i++) {

                    for (int j = 0; j  codeOut.length; j++) {

                        if (codeOut[j][i]) {  

                            gs.fillRect(j * 3 + pixoff, i * 3 + pixoff, 3, 3);

                        }  

                    }  

                }  

            } else {  

                System.err.println(“QRCode content bytes length = ” + contentBytes.length + ” not in [ 0,130 ]. “);  

            }

           /* 判斷是否需要添加logo圖片 */

            if(logoPath != null){

                File icon = new File(logoPath);

                if(icon.exists()){

                    int width_4 = imgSize / 4;

                    int width_8 = width_4 / 2;

                    int height_4 = imgSize / 4;

                    int height_8 = height_4 / 2;

                    Image img = ImageIO.read(icon);

                    gs.drawImage(img, width_4 + width_8, height_4 + height_8,width_4,height_4, null);

                    gs.dispose();

                    bufImg.flush();

                }else{

                    System.out.println(“Error: login圖片還在在!”);

                }

            }

            gs.dispose();

            bufImg.flush();

            //創建二維碼文件

            File imgFile = new File(imgPath);

            if(!imgFile.exists())

                imgFile.createNewFile();

            //根據生成圖片獲取圖片

            String imgType = imgPath.substring(imgPath.lastIndexOf(“.”) + 1, imgPath.length());

            // 生成二維碼QRCode圖片  

            ImageIO.write(bufImg, imgType, imgFile);  

         } catch (Exception e) {  

             e.printStackTrace();  

         }

    }

    

    /**

     * span style=”font-size:18px;font-weight:blod;”QRCode二維碼解析/span

     * @param codePath    二維碼路徑

     * @return    解析結果

     */

    public static String QRCodeAnalyze(String codePath) {

        File imageFile = new File(codePath);

        BufferedImage bufImg = null;  

        String decodedData = null;  

        try {

            if(!imageFile.exists())

                return “二維碼不存在”;

            bufImg = ImageIO.read(imageFile);

          

            QRCodeDecoder decoder = new QRCodeDecoder();  

            decodedData = new String(decoder.decode(new ImageUtil(bufImg)), “gb2312”);  

        } catch (IOException e) {  

            System.out.println(“Error: ” + e.getMessage());  

            e.printStackTrace();  

        } catch (DecodingFailedException dfe) {  

            System.out.println(“Error: ” + dfe.getMessage());  

            dfe.printStackTrace();  

        }

        return decodedData;

    }

}

3、最後貼測試代碼:

package test;

import java.awt.image.BufferedImage;

import java.io.InputStream;

import java.net.URL;

import javax.imageio.ImageIO;

import common.ImageUtil;

import common.QRCodeUtil;

import jp.sourceforge.qrcode.QRCodeDecoder;

/**

 * 二維碼生成測試類

 * @author Cloud

 * @data   2016-11-21

 * QRCodeTest

 */

public class QRCodeTest {

    public static void main(String[] args) throws Exception {

        /**

         *    QRcode 二維碼生成測試

         *    QRCodeUtil.QRCodeCreate(“”, “E://qrcode.jpg”, 15, “E://icon.png”);

         */

        /**

         *     QRcode 二維碼解析測試

         *    String qrcodeAnalyze = QRCodeUtil.QRCodeAnalyze(“E://qrcode.jpg”);

         */

        /**

         * ZXingCode 二維碼生成測試

         * QRCodeUtil.zxingCodeCreate(“”, 300, 300, “E://zxingcode.jpg”, “jpg”);

         */

        /**

         * ZxingCode 二維碼解析

         *    String zxingAnalyze =  QRCodeUtil.zxingCodeAnalyze(“E://zxingcode.jpg”).toString();

         */

        System.out.println(“success”);

    }

}

java spingmvc 怎麼生成二維碼 在頁面顯示

我只說一下後端實現方式,至於前端怎麼實現我沒做過。

在後台生成一個二維碼圖片(生成方式網上一大堆),生成之後上傳到伺服器上,去到地址,將地址傳到頁面上,就可以顯示了

如何使用java開發二維碼代碼

1: 使用SwetakeQRCode在Java項目中生成二維碼

下載地址

或著

這個是日本人寫的,生成的是我們常見的方形的二維碼

可以用中文

如:5677777ghjjjjj

2: 使用BarCode4j生成條形碼和二維碼

BarCode4j網址:

barcode4j是使用datamatrix的二維碼生成演算法,為支持qr的演算法

datamatrix是歐美的標準,qr為日本的標準,

barcode4j一般生成出來是長方形的

如:88777alec000yan

這個博客這方面說的挺清楚的:

3:zxing

zxing 這個是google的

下載地址

Java代碼:

import java.io.File;

import java.util.Hashtable;

import com.google.zxing.BarcodeFormat;

import com.google.zxing.EncodeHintType;

import com.google.zxing.MultiFormatWriter;

import com.google.zxing.client.j2se.MatrixToImageWriter;

import com.google.zxing.common.BitMatrix;

import com.google.zxing.qrcode.QRCodeWriter;

public class QRCodeEvents {

public static void main(String []args)throws Exception{

String text = “你好”;

int width = 100;

int height = 100;

String format = “png”;

Hashtable hints= new Hashtable();

hints.put(EncodeHintType.CHARACTER_SET, “utf-8”);

BitMatrix bitMatrix = new MultiFormatWriter().encode(text, BarcodeFormat.QR_CODE, width, height,hints);

File outputFile = new File(“new.png”);

MatrixToImageWriter.writeToFile(bitMatrix, format, outputFile);

}

}

4:google chart api就有實現二維碼的方法

利用這個api,使用google appengine進行實現。

5:JS生成二維碼

使用jQuery-qrcode生成二維碼

先簡單說一下jquery-qrcode,這個開源的三方庫(可以從 獲取),

qrcode.js 是實現二維碼數據計算的核心類,

jquery.qrcode.js 是把它用jquery方式封裝起來的,用它來實現圖形渲染,其實就是畫圖(支持canvas和table兩種方式)

支持的功能主要有:

Js代碼:

text : “” //設置二維碼內容

Js代碼:

render : “canvas”,//設置渲染方式

width : 256, //設置寬度

height : 256, //設置高度

typeNumber : -1, //計算模式

correctLevel : QRErrorCorrectLevel.H,//糾錯等級

background : “#ffffff”,//背景顏色

foreground : “#000000” //前景顏色

使用方式非常簡單

Js代碼:

jQuery(‘#output’).qrcode({width:200,height:200,correctLevel:0,text:content});

經過簡單實踐,

使用canvas方式渲染性能還是非常不錯的,但是如果用table方式,性能不太理想,特別是IE9以下的瀏覽器,所以需要自行優化一下渲染table的方式,這裡就不細述了。

其實上面的js有一個小小的缺點,就是默認不支持中文。

這跟js的機制有關係,jquery-qrcode這個庫是採用 charCodeAt() 這個方式進行編碼轉換的,

而這個方法默認會獲取它的 Unicode 編碼,一般的解碼器都是採用UTF-8, ISO-8859-1等方式,

英文是沒有問題,如果是中文,一般情況下Unicode是UTF-16實現,長度2位,而UTF-8編碼是3位,這樣二維碼的編解碼就不匹配了。

解決方式當然是,在二維碼編碼前把字元串轉換成UTF-8,具體代碼如下:

function utf16to8(str) {

var out, i, len, c;

out = “”;

len = str.length;

for(i = 0; i len; i++) {

c = str.charCodeAt(i);

if ((c = 0x0001) (c = 0x007F)) {

out += str.charAt(i);

} else if (c 0x07FF) {

out += String.fromCharCode(0xE0 | ((c 12) 0x0F));

out += String.fromCharCode(0x80 | ((c 6) 0x3F));

out += String.fromCharCode(0x80 | ((c 0) 0x3F));

} else {

out += String.fromCharCode(0xC0 | ((c 6) 0x1F));

out += String.fromCharCode(0x80 | ((c 0) 0x3F));

}

}

return out;

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/259754.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-15 16:30
下一篇 2024-12-15 16:30

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論