生成一维条形码并转换base64返回给前端展示

项目场景:

提示:这里简述项目相关背景:

在后端随机生成一维条形码给前端展示
效果图:
自动生成的一维码


引入pom

	<dependency>
        <groupId>net.sf.barcode4j</groupId>
        <artifactId>barcode4j-light</artifactId>
        <version>2.0</version>
    </dependency>

代码:

1、生成所需的条码数字:

//获取15位随机数字
  	cdk = RandomNumUtils.getRandomNum(15);
//生成随机数的工具类
public class RandomNumUtils {
    public static String getRandomNum(Integer length){
        String data = "";
        Random random = new Random();
        for (Integer i = 0; i < length; i++) {
            data += String.valueOf(random.nextInt(10));
        }
        return data;
    }
}

2、绘制条码图片并转换成base64:

//根据传入的code参数绘制条码图片 并返回base64
public static String getBarCodeToBase64(String code){
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
        generate(code, outputStream);
        Base64.Encoder encoder = Base64.getEncoder();
        return encoder.encodeToString(outputStream.toByteArray());
    }
//绘制图片到流
public static void generate(String msg, OutputStream ous) {
        if (StringUtils.isEmpty(msg) || ous == null) {
            return;
        }

        Code39Bean bean = new Code39Bean();

        // 精细度
        final int dpi = 150;
        // module宽度
        final double moduleWidth = UnitConv.in2mm(1.0f / dpi);

        // 配置对象
        bean.setModuleWidth(moduleWidth);
        bean.setWideFactor(3);
        bean.doQuietZone(false);

        String format = "image/png";
        try {

            // 输出到流
            BitmapCanvasProvider canvas = new BitmapCanvasProvider(ous, format, dpi,
                    BufferedImage.TYPE_BYTE_BINARY, false, 0);

            // 生成条形码
            bean.generateBarcode(canvas, msg);

            // 结束绘制
            canvas.finish();
        } catch (IOException e) {
            throw new RuntimeException(e);
        }
    }

3、计算出的base64存入数据库 (用blob类型存储)

数据库字段

4、展示到前端

<el-dialog :title="title" :visible.sync="cdkCodeOpen" width="400px" append-to-body>
      <div style="text-align: center ">
      //此处cdkBase64的值从后端取
        <img :src="'data:image/jpeg;base64,' + cdkBase64" alt="" align="center">
      </div>
      <div slot="footer" class="dialog-footer">
        <el-button type="primary" @click="cancelCdkCode">确 定</el-button>
      </div>
    </el-dialog>

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值