本文目錄一覽:
如何用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