[代码整理] 使用zxing生成二维码并前台显示!

使用zxing生成二维码并前台显示


##业务需求:
近期项目中要使用将信息存入二维码,供用户微信扫描读取!提高实际工作中得工作效率


##思路:
-**1.在前台将需要生成得信息,通过servlet传入后端
-**2.将信息进行处理,使用zxing生成二维码图片!
-**3.因为要返回到前台所以就不生成具体图片文件。所以直接将生成的二维码二进制图片流
-**4.将得到的图片流,通过输出流传到前台


##工具简介:
ZXing是一个开放源码的,用Java实现的多种格式的1D/2D条码图像处理库,它包含了联系到其他语言的端口。Zxing可以实现使用手机的内置的摄像头完成条形码的扫描及解码。该项目可实现的条形码编码和解码。


##方法实现:

1.通过maven引入zxing的jar包

<dependency>
	<groupId>com.google.zxing</groupId>
	<artifactId>core</artifactId>
	<version>3.3.1</version>
</dependency>
<dependency>
	<groupId>com.google.zxing</groupId>
	<artifactId>javase</artifactId>
	<version>3.3.1</version>
</dependency>

2.写QRUtils工具包

import java.awt.BasicStroke;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Image;
import java.awt.Shape;
import java.awt.geom.RoundRectangle2D;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.util.Arrays;
import java.util.Hashtable;

import javax.imageio.ImageIO;

import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;


public class QRCodeUtil {

    private static final String CHARSET = "utf-8";
    private static final String FORMAT_NAME = "JPG";
    // 二维码尺寸
    private static final int QRCODE_SIZE = 300;
    // LOGO宽度
    private static final int WIDTH = 60;
    // LOGO高度
    private static final int HEIGHT = 60;

    private static BufferedImage createImage(String content, String imgPath,
                                             boolean needCompress) throws Exception {
        Hashtable hints = new Hashtable();
        hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
        hints.put(EncodeHintType.CHARACTER_SET, CHARSET);
        hints.put(EncodeHintType.MARGIN, 1);
        BitMatrix bitMatrix = new MultiFormatWriter().encode(content,
                BarcodeFormat.QR_CODE, QRCODE_SIZE, QRCODE_SIZE, hints);
        int width = bitMatrix.getWidth();
        int height = bitMatrix.getHeight();
        BufferedImage image = new BufferedImage(width, height,
                BufferedImage.TYPE_INT_RGB);
        for (int x = 0; x < width; x++) {
            for (int y = 0; y < height; y++) {
                image.setRGB(x, y, bitMatrix.get(x, y) ? 0xFF000000
                        : 0xFFFFFFFF);
            }
        }
        if (imgPath == null || "".equals(imgPath)) {
            return image;
        }
        // 插入图片
        QRCodeUtil.insertImage(image, imgPath, needCompress);
        return image;
    }


    private static void insertImage(BufferedImage source, String imgPath,
                                    boolean needCompress) throws Exception {
        File file = new File(imgPath);
        if (!file.exists()) {
            System.err.println(""+imgPath+"   该文件不存在!");
            return;
        }
        Image src = ImageIO.read(new File(imgPath));
        int width = src.getWidth(null);
        int height = src.getHeight(null);
        if (needCompress) { // 压缩LOGO
            if (width > WIDTH) {
                width = WIDTH;
            }
            if (height > HEIGHT) {
                height = HEIGHT;
            }
            Image image = src.getScaledInstance(width, height,
                    Image.SCALE_SMOOTH);
            BufferedImage tag = new BufferedImage(width, height,
                    BufferedImage.TYPE_INT_RGB);
            Graphics g = tag.getGraphics();
            g.drawImage(image, 0, 0, null); // 绘制缩小后的图
            g.dispose();
            src = image;
        }
        // 插入LOGO
        Graphics2D graph = source.createGraphics();
        int x = (QRCODE_SIZE - width) / 2;
        int y = (QRCODE_SIZE - height) / 2;
        graph.drawImage(src, x, y, width, height, null);
        Shape shape = new RoundRectangle2D.Float(x, y, width, width, 6, 6);
        graph.setStroke(new BasicStroke(3f));
        graph.draw(shape);
        graph.dispose();
    }

    //获取生成二维码的图片流
    public static ByteArrayOutputStream encodeIO(String content,String imgPath,Boolean needCompress) throws Exception {
        BufferedImage image = QRCodeUtil.createImage(content, imgPath,
                needCompress);
        //创建储存图片二进制流的输出流
        ByteArrayOutputStream baos = new ByteArrayOutputStream();
        //将二进制数据写入ByteArrayOutputStream
        ImageIO.write(image, "jpg", baos);
		return baos;
	}
    //测试
    public static void main(String[] args) throws Exception {
        String text = "ifarm";
        //QRCodeUtil.encode(text, "D:\\图片\\武僧2.jpg", "d:/MyWorkDoc", true);
        //String decode = QRCodeUtil.decode("D:\\MyWorkDoc\\32533141.jpg");
        ByteArrayOutputStream encodeIO = QRCodeUtil.encodeIO(text, "D:\\图片\\武僧2.jpg", true);
        //输入数组
     System.out.println(Arrays.toString(encodeIO.toByteArray()));
    }
}

3.后台Controller

@RequestMapping(value = "/getQRCode", method = RequestMethod.GET)
public void getQRCode(HttpServletRequest request, HttpServletResponse response) throws Exception {
	//获取前台传入的信息,此处可操作性很大,大家可以通过自己查询数据库,或者通过判断填入其他信息
      String content = request.getParameter("content");
      //二维码图片中间logo
      String imgPath = "";
	Boolean needCompress = true; 
	//通过调用我们的写的工具类,拿到图片流
	ByteArrayOutputStream out = QRCodeUtil.encodeIO(content, imgPath, needCompress);
	//定义返回参数
	response.setCharacterEncoding("UTF-8");
	response.setContentType("image/jpeg;charset=UTF-8");
	response.setContentLength(out.size());
	ServletOutputStream outputStream = response.getOutputStream();
	outputStream.write(out.toByteArray());
	outputStream.flush();
	outputStream.close();
}

4.前端
-html

<h1>测试二维码页面</h1>
<div class="input-group">
	<span class="input-group-addon" >耳号</span>
	<input type="text" class="form-control" placeholder="请输入" id="swineEar">
	<span class="input-group-addon"><i class="glyphicon glyphicon-search"></i></span>
 </div>
 <div>
	<div style="float: left;">
	<img src="" id="npcImg" width="300" height="300"/>
	<input type="hidden" id="photo" name="photo"/>
	</div>
</div>

-js

function doCode () {
    $('#npcImg').removeAttr('src')
    var npcName = document.getElementById("swineEar").value;
    if(npcName === ''){
        alert('耳号为空,不能生成二维码')
    }else{
        var img = document.getElementById("npcImg");
        img.src = '/getQRCode?content='+npcName;
    }
}

##总结:
记录再此为为自己总结,也希望能够帮到其他人!
具体步骤解析,在代码中都有注释,应该不需要做过多解释了。希望能对大家有所帮助!
正常项目中使用直接copy过去直接就能使用了!
觉得不错的话,点个拇指!

评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值