qrcode(二)

上篇中小编主要是对二维码进行了理论上的总结。这篇主要是用三种不同的方式,实现简单的二维码的创建和读取功能。

1、zxing(下载链接:http://download.csdn.net/download/u013035612/10112948

1)创建java-project,引入zxing.jar

2)生成二维码类:CreateQrCode

public class CreateQRCode {

	public static void main(String[] args) throws IOException {
		
		//定义二维码宽高等属性
		int width=300;
		int height=300;
		String format="png";
		String content="你扫我呀。";
		
		//定义二维码参数
		HashMap hs=new HashMap();
		hs.put(EncodeHintType.CHARACTER_SET, "utf-8");//编码格式
		hs.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.M);//容错级别
		hs.put(EncodeHintType.MARGIN, 2);
		
		//生成二维码
		try {
			BitMatrix bitMatrix=new MultiFormatWriter().encode(content,BarcodeFormat.QR_CODE,width,height,hs);
			Path file=new File("D:/code/img.png").toPath();
			MatrixToImageWriter.writeToPath(bitMatrix,format,file);
		} catch (WriterException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
	}

}

3)读取二维码信息类:ReadQRCode

public class ReadQRCode {
	
	public static void main(String[] args) throws IOException, NotFoundException {
		MultiFormatReader formatReader=new MultiFormatReader();
		
		File file=new File("D:/code/img.png");
		
		BufferedImage image=ImageIO.read(file);
		
		BinaryBitmap binaryBitmap=new BinaryBitmap(new HybridBinarizer(new BufferedImageLuminanceSource(image)));
		
		//定义二维码参数
		HashMap hs=new HashMap();
		hs.put(EncodeHintType.CHARACTER_SET, "utf-8");//编码格式
		
		Result result=formatReader.decode(binaryBitmap,hs);
		
		System.out.println("解析结果:"+result.toString());
		System.out.println("二维码格式类型:"+result.getBarcodeFormat());
		System.out.println("二维码文本内容:"+result.getText());
	}
}


2、qrcode

1)引入qrcode.jar

2)新建java-project

3)代码实现

·MYQRCodeImage工具类

public class MYQRCodeImage implements QRCodeImage {

	BufferedImage bufferedImage;
	
	public MYQRCodeImage(BufferedImage bufferedImage){
		this.bufferedImage=bufferedImage;
	}

	public int getHeight() {
		return bufferedImage.getHeight();
	}

	@Override
	public int getPixel(int arg0, int arg1) {
		return bufferedImage.getRGB(arg0, arg1);
	}

	@Override
	public int getWidth() {
		return bufferedImage.getWidth();
	}

}


·生成二维码类

public class CreateQRcode {

	public static void main(String[] args) throws IOException {
		Qrcode x=new Qrcode();
		x.setQrcodeErrorCorrect('M');//纠错等级
		x.setQrcodeEncodeMode('B');//N代表数字,A代表a-Z,B代表其他字符
		x.setQrcodeVersion(7);//版本
		String qrData="能扫到我,就成功啦。";
		int width=67+12*(7-1);
		int height=67+12*(7-1);
		BufferedImage bufferedImage=new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
		Graphics2D gs=bufferedImage.createGraphics();
		gs.setBackground(Color.WHITE);
		gs.setColor(Color.BLACK);
		gs.clearRect(0, 0, width, height);
		
		int pixoff=2;//偏移量
		
		byte[] d =qrData.getBytes("gb2312");
		if (d.length>0 && d.length <120){
		    boolean[][] s = x.calQrcode(d);
		    for (int i=0;i<s.length;i++){
			for (int j=0;j<s.length;j++){
			    if (s[j][i]) {
				gs.fillRect(j*3+pixoff,i*3,3,3);
			    }
			}
		    }
		}
		gs.dispose();
		bufferedImage.flush();
		ImageIO.write(bufferedImage, "png", new File("D:/code/qrcode.png"));
	}

}

·读取二维码类


public class ReadQRCode {
	public static void main(String[] args) throws IOException {
		
		File file=new File("D:/code/qrcode.png");
		
		BufferedImage bufferedImage=ImageIO.read(file);
		
		QRCodeDecoder codeDecoder=new QRCodeDecoder();
		
		String result=new String(codeDecoder.decode(new MYQRCodeImage(bufferedImage)),"gb2312");
		
		System.out.println(result);
	}
}


3、使用jquery.qrcode.js

1)新建java-web项目

2)引入jquery.js和jquery.qrcode.min.js

3)新建一个jsp页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>生成二维码</title>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery.min.js"></script>
<script type="text/javascript" src="<%=request.getContextPath() %>/js/jquery.qrcode.min.js"></script>
</head>
<body>
生成的二维码如下:
<div id="qrcode"></div>
<script type="text/javascript">
	jQuery('#qrcode').qrcode("http://baidu.com");//可以是文本,也可以是链接(可以直接访问到链接)
</script>
</body>
</html>


小结:

通过这三种方式,都可以生成二维码。非常简单,容易上手。当然还可以将上述二维码中包含的文字换成链接,从而可以访问某个页面。使用VCard实现二维码扫描安装手机软件。(腾讯域名下的apk)等。


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue中使用qrcode生成二维码,你可以按照以下步骤进行操作: 1. 首先,你需要安装qrcode插件,你可以使用npm命令来安装:npm i qrcode -S 。 2. 然后,在你的Vue组件中引入qrcode插件:import QRCode from 'qrcode' 。 3. 接下来,在你的Vue组件的template中添加一个img标签,用于显示生成的二维码图片。例如: ``` <template> <div> <img :src="QRImgUrl" /> </div> </template> ``` 4. 在Vue组件的script中,使用QRCode生成二维码的方法。首先,你需要定义一个data属性QRImgUrl用于存储生成的二维码图片的URL。然后,在created钩子函数中调用getQRcode方法来生成二维码。getQRcode方法使用QRCode.toDataURL来生成二维码图片的DataURL,并将生成的URL赋值给QRImgUrl。例如: ``` <script> import QRCode from 'qrcode' export default { data() { return { QRImgUrl: '', QRlink:'www.xxx.com' } }, created() { this.getQRcode() }, methods: { getQRcode(){ QRCode.toDataURL(this.QRlink, { errorCorrectionLevel: 'L', margin: 2, width: 128 }, (err, url) => { if (err) throw err this.QRImgUrl = url }) } } } </script> ``` 这样,当你的Vue组件被创建时,getQRcode方法会被调用,生成二维码并将URL赋值给QRImgUrl,从而显示在页面上 。 如果你想对生成的二维码进行更详细的配置,你可以参考以下步骤: 1. 在getQRcode方法中定义一个opts对象,用于配置生成二维码的各种参数,比如容错级别、二维码类型、二维码质量、留白边距等 。 2. 修改QRCode.toDataURL方法的第二个参数为opts,这样可以根据opts的配置生成更加符合你需求的二维码 。 例如,你可以按照以下方式配置opts对象: ```javascript let opts = { errorCorrectionLevel: "L",//容错级别 type: "image/png",//生成的二维码类型 quality: 0.3,//二维码质量 margin: 5,//二维码留白边距 width: 128,//宽 height: 128,//高 text: "http://www.xxx.com",//二维码内容 color: { dark: "#666666",//前景色 light: "#fff"//背景色 } }; ``` 然后,将opts作为QRCode.toDataURL方法的第二个参数传入: ```javascript QRCode.toDataURL(this.QRlink, opts, (err, url) => { if (err) throw err this.QRImgUrl = url }) ``` 这样,你就可以根据opts的配置生成定制化的二维码 。 综上所述,你可以按照以上步骤在Vue中使用qrcode生成二维码,并根据需要进行详细的配置 。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值