网站首页 > 技术文章 正文
摘要
这次分享给大家的是,如何将导入的excel数据,将某些字段生成base64位的二维码。
效果图
后台开发
1、pom.xml 相关jar引入
2、代码
@PostMapping("/importData")
@ResponseBody
public AjaxResult importData(MultipartFile file, boolean updateSupport, String code) throws Exception
{
System.out.println(code);
ExcelUtil<SqJcitem> util = new ExcelUtil<SqJcitem>(SqJcitem.class);
List<SqJcitem> userList = util.importExcel(file.getInputStream());
Date date= new Date();
SimpleDateFormat dateFormat=new SimpleDateFormat("yyyy-MM-dd");
String time=dateFormat.format(date);
System.out.println("---"+time);
for(int i=0;i<userList.size();i++)
{
if(StringUtils.isNotBlank(userList.get(i).getCode()))
{
SqJcitem n=userList.get(i);
List<SqJcitem> sqjcitemList= sqjcitemDao.listByCode(n.getCode());
if(sqjcitemList.size()==0)
{
SqJcitem sqjcitem=new SqJcitem();
sqjcitem.setCode(code+"-"+n.getCode()+"-"+n.getJcode()+"-"+time);
sqjcitem.setItems(n.getItems());
sqjcitem.setItemsname(n.getItemsname());
sqjcitem.setMethodcode(n.getMethodcode());
sqjcitem.setMethondname(n.getMethondname());
sqjcitem.setFxitems(n.getFxitems());
sqjcitem.setImg(QrCodeUtils.creatRrCode(sqjcitem.getCode(), 200,200));//生成base64的二维码
sqjcitemDao.insert(sqjcitem);
}
}
}
return AjaxResult.success("");
}
工具类 QrCodeUtils
package com.stylefeng.guns.modular.util;
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;
import sun.misc.BASE64Encoder;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.Hashtable;
public class QrCodeUtils {
public static String creatRrCode(String contents, int width, int height) {
String binary = null;
Hashtable hints = new Hashtable();
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
try {
BitMatrix bitMatrix = new MultiFormatWriter().encode(
contents, BarcodeFormat.QR_CODE, width, height, hints);
// 1、读取文件转换为字节数组
ByteArrayOutputStream out = new ByteArrayOutputStream();
BufferedImage image = toBufferedImage(bitMatrix);
//转换成png格式的IO流
ImageIO.write(image, "png", out);
byte[] bytes = out.toByteArray();
// 2、将字节数组转为二进制
BASE64Encoder encoder = new BASE64Encoder();
binary = encoder.encodeBuffer(bytes).trim();
} catch (WriterException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return binary;
}
/**
* image流数据处理
*
* @author ianly
*/
public static BufferedImage toBufferedImage(BitMatrix matrix) {
int width = matrix.getWidth();
int height = matrix.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, matrix.get(x, y) ? 0xFF000000 : 0xFFFFFFFF);
}
}
return image;
}
public static void main(String[] args) {
String binary = QrCodeUtils.creatRrCode("https://blog.csdn.net/ianly123", 200,200);
System.out.println(binary);
}
}
猜你喜欢
- 2025-08-31 如何利用 Python 自动发邮件,打工人福音
- 2025-08-31 Python内置模块base64 :Base16, Base32, Base64, Base85 编码详解
- 2025-08-31 java调用API操作GitLab_java调用git的接口
- 2025-08-31 SpringBoot中7个文件上传下载工具
- 2025-08-31 java项目中接入大模型,简历必备_java介绍项目中做过的模块
- 2025-08-31 spring boot-MultipartFile 机制_spring boot multipartfile为null
- 2025-05-28 教你一招快速入门网络编程
- 2025-05-28 有了这些开源工具后,明天争取五点下班了!
- 2025-05-28 十年老架构师:带你读懂springmvc的世界!
- 2025-05-28 一招搞定外部请求,这款 HTTP 客户端框架真的很强大!
- 最近发表
-
- fail-safe 和 fail-fast 都是什么鬼?
- 办公小技巧:Word“安全模式”用通透
- 新来的妹子误执行 “rm -rf” !_七零大院新来的小美人是黑道千金
- 如何利用 Python 自动发邮件,打工人福音
- Python内置模块base64 :Base16, Base32, Base64, Base85 编码详解
- java调用API操作GitLab_java调用git的接口
- spingboot 实现导入excel数据生成二维码
- SpringBoot中7个文件上传下载工具
- java项目中接入大模型,简历必备_java介绍项目中做过的模块
- spring boot-MultipartFile 机制_spring boot multipartfile为null
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- windowsscripthost (69)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)