java生成二维码
前言:
先聊聊题外话,话说在1994年,日本的丰田汽车公司独立出来了一个电装公司。由于高精度的汽车零配件需要匹配很多信息,而传统的条形码容量有限,在电装公司的腾弘原的带领下,经过两年时间,发明了二维码,二维码信息存储量是条形码的250倍。
然而,日本人并没有重视这项发明。这时我们勤劳勇敢的龙的传人坐不住了,在2011年由于淘宝的壮大,二维码支付由支付宝正式引入中国,同时某人还拿下了二维码扫一扫专利,光依靠海外专利权就赚了至少7个亿。
本来是日本人发明的,到最后日本人不但没有得到专利费,用自己的东西还得交专利费,是不是大快人心?
步入正题,在当今二维码横行的时代,我们做项目时肯定也会遇到要生成二维码的时候,接下来就看看如何生成二维码。点我下载源码。
java生成二维码demo:
本demo基于springboot。
1、添加依赖:
<!-- 二维码相关 --> <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.3.0</version> </dependency> <!-- 长链接转短链接 相关 --> <dependency> <groupId>org.apache.httpcomponents</groupId> <artifactId>httpclient</artifactId> </dependency>
2、编写工具类:
ShortNetAddressUtil.java:
import java.util.ArrayList; import java.util.List; import org.apache.http.HttpResponse; import org.apache.http.NameValuePair; import org.apache.http.client.entity.UrlEncodedFormEntity; import org.apache.http.client.methods.HttpPost; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.message.BasicNameValuePair; import org.apache.http.util.EntityUtils; /** * * 长链接转短链接的工具类<br> * @author zhu * */ public class ShortNetAddressUtil { public static CloseableHttpClient httpclient; static { httpclient = HttpClients.createDefault(); } /** * 生成短连接信息 */ public static String generateShortUrl(String url) { try { HttpPost httpost = new HttpPost("http://suo.im/api.php"); List<NameValuePair> params = new ArrayList<NameValuePair>(); params.add(new BasicNameValuePair("format", "utf-8")); // 编码 params.add(new BasicNameValuePair("url", url)); // 用户名称 httpost.setEntity(new UrlEncodedFormEntity(params, "utf-8")); HttpResponse response = httpclient.execute(httpost); String jsonStr = EntityUtils.toString(response.getEntity(), "utf-8"); return jsonStr; } catch (Exception e) { e.printStackTrace(); return "Error"; } } /** * 测试生成短连接 */ public static void main(String[] args) { String url = generateShortUrl( "https://www.baidu.com/s?wd=%E7%A0%81%E4%BA%91&rsv_spt=1&rsv_iqid=0x964c1c3500030761&issp=1&f=8&rsv_bp=1&rsv_idx=2&ie=utf-8&rqlang=cn&tn=48021271_11_hao_pg&rsv_enter=1&oq=spring%2520data%2520jpa%25E8%2587%25AA%25E5%25AE%259A%25E4%25B9%2589%25E6%2596%25B9%25E6%25B3%2595%25E8%25A7%2584%25E8%258C%2583&rsv_t=d5f86AreI8IAKjbxCKuUMFkUO6EKFeso61joDwkdQQrpLo%2BgDuuyujzyCafz%2B5gC8IMw8TR3iRoe&rsv_pq=f35da7870001b1ba&inputT=7063&rsv_sug3=74&rsv_sug1=50&rsv_sug7=100&bs=spring%20data%20jpa%E8%87%AA%E5%AE%9A%E4%B9%89%E6%96%B9%E6%B3%95%E8%A7%84%E8%8C%83"); System.out.println(url); } }
测试结果:
注意:
这个工具类用来将长链接转换成短链接。在实际项目中,二维码往往都与微信或支付宝挂钩,而与它们挂钩的话链接必然很长,太长的链接会降低二维码的识别速度以及识别率,所以要将它们转换成短链接。常用的缩短网址接口有百度的,新浪的,但是我按照网上的测试百度和新浪的都失败了,所以用了suo.im这个网的接口。这个接口经测试可用,但是偶尔扫码时偶尔会扫出广告。如果知道怎么用百度接口或者新浪接口的老铁还请赐教哦!
QRCodeUtil.java:
import java.util.HashMap; import java.util.Map; import javax.servlet.http.HttpServletResponse; import com.google.zxing.BarcodeFormat; import com.google.zxing.EncodeHintType; import com.google.zxing.MultiFormatWriter; import com.google.zxing.WriterException; import com.google.zxing.common.BitMatrix; /** * 生成二维码图片流 * * @author zhu * */ public class QRCodeUtil { public static BitMatrix generateQRCodeStream(String content,HttpServletResponse response) { //给相应添加头部信息,主要告诉浏览器返回的是图片流 response.setHeader("Cache-Control", "no-store"); // 不设置缓存 response.setHeader("Pragma", "no-cache"); response.setDateHeader("Expires", 0); response.setContentType("image/png"); //设置图片的文字编码以及内边框 Map<EncodeHintType, Object> hints = new HashMap<>(); //编码 hints.put(EncodeHintType.CHARACTER_SET, "UTF-8"); //边框距 hints.put(EncodeHintType.MARGIN, 0); BitMatrix bitMatrix; try { //参数分别为:编码内容、编码类型、图片宽度、图片高度,设置参数 bitMatrix = new MultiFormatWriter().encode(content, BarcodeFormat.QR_CODE, 300, 300,hints); }catch(WriterException e) { e.printStackTrace(); return null; } return bitMatrix; } }
这个工具类的BitMatrix
方法就是将传入的content
生成二维码。
3、编写Controller:
import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.ResponseBody; import com.google.zxing.client.j2se.MatrixToImageWriter; import com.google.zxing.common.BitMatrix; import com.zhu.QRCodeTest.util.QRCodeUtil; import com.zhu.QRCodeTest.util.ShortNetAddressUtil; /** * 测试生成二维码 * * @author zhu * */ @Controller @RequestMapping("/qrcode") public class QRCodeTestController { @RequestMapping(value = "/generateqrcode", method = RequestMethod.GET) @ResponseBody public void generateQRCode4Product(HttpServletRequest request, HttpServletResponse response) { String longUrl; try { longUrl = "https://www.jianshu.com/u/c0aa31157ba5"; // 转换成短url String shortUrl = ShortNetAddressUtil.generateShortUrl(longUrl); // 生成二维码 BitMatrix qRcodeImg = QRCodeUtil.generateQRCodeStream(shortUrl, response); // 将二维码输出到页面中 MatrixToImageWriter.writeToStream(qRcodeImg, "png", response.getOutputStream()); } catch (Exception e) { e.printStackTrace(); } } }
注意:
这个controller首先是先定义了一个longUrl,然后调用工具类转换成短shortUrl,再调用生成二维码的工具类,传入shortUrl,生成二维码,最后用response输出到页面中。
这里并没有用到HttpServletRequest
,删掉也可以。在实际项目开发中,longUrl肯定不是写死的,肯定是根据前端传入的各种参数拼接而成,HttpServletRequest
就是用来获取前端参数的。
测试:
在浏览器直接输入localhost:8080/qrcode/generateqrcoe
,就可看到二维码。
手机任意工具扫描二维码就可以进入到刚才controller中写的longUrl。
在页面中显示二维码只需要用img标签,src指向该controller路由即可。如下:
4、前端页面:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Insert title here</title> </head> <body> <img alt="二维码" src="/qrcode/generateqrcode"> </body> </html>
访问前端页面:
经测试,二维码也是有效的。
总结:
生成二维码其实也挺简单的,说白了就是两个工具类以及一个将二维码输出到客户端的controller。
以上内容属于个人笔记整理,如有错误,欢迎批评指正!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Web Worker 使用教程
一、概述 JavaScript 语言采用的是单线程模型,也就是说,所有任务只能在一个线程上完成,一次只能做一件事。前面的任务没做完,后面的任务只能等着。随着电脑计算能力的增强,尤其是多核 CPU 的出现,单线程带来很大的不便,无法充分发挥计算机的计算能力。 Web Worker 的作用,就是为 JavaScript 创造多线程环境,允许主线程创建 Worker 线程,将一些任务分配给后者运行。在主线程运行的同时,Worker 线程在后台运行,两者互不干扰。等到 Worker 线程完成计算任务,再把结果返回给主线程。这样的好处是,一些计算密集型或高延迟的任务,被 Worker 线程负担了,主线程(通常负责 UI 交互)就会很流畅,不会被阻塞或拖慢。 Worker 线程一旦新建成功,就会始终运行,不会被主线程上的活动(比如用户点击按钮、提交表单)打断。这样有利于随时响应主线程的通信。但是,这也造成了 Worker 比较耗费资源,不应该过度使用,而且一旦使用完毕,就应该关闭。 Web Worker 有以下几个使用注意点。 (1)同源限制 分配给 Worker 线程运行的脚本文件,必须与主线程...
- 下一篇
disconf配置文件获取失败
启动程序报错: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'springPropertyConfigurer' defined in URL [jar:file:/home/fightfaith/develop/tomcat/webapps/cc-manage-web/WEB-INF/lib/cc-manage-resource-0.0.1.jar!/applicationContext.xml]: Cannot resolve reference to bean 'configproperties_no_reloadable_disconf' while setting bean property 'propertiesArray' with key [0]; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean w...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Hadoop3单机部署,实现最简伪集群
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- MySQL8.0.19开启GTID主从同步CentOS8