欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java实现二维码生成的几个方法(推荐)

程序员文章站 2024-03-11 14:33:31
java实现二维码生成的几个方法,具体如下: 1: 使用swetakeqrcode在java项目中生成二维码 下载地址 或着 这个是日本人写...

java实现二维码生成的几个方法,具体如下:

1: 使用swetakeqrcode在java项目中生成二维码

下载地址

或着

这个是日本人写的,生成的是我们常见的方形的二维码

可以用中文

如:5677777ghjjjjj

2: 使用barcode4j生成条形码和二维码

barcode4j网址:http://sourceforge.net/projects/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   : "https://github.com/jeromeetienne/jquery-qrcode" //设置二维码内容 

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;  
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。