生成二维码

一、Java生成二维码

1、引入依赖

		<!--生成二维码-->
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.3.10</version>
        </dependency>
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>core</artifactId>
            <version>3.3.3</version>
        </dependency>
        <dependency>
            <groupId>com.google.zxing</groupId>
            <artifactId>javase</artifactId>
            <version>3.4.0</version>
        </dependency>

2、编写service类及方法

@Service
@Slf4j
public class QRCodeService {
    // 自定义参数,这部分是Hutool工具封装的
    private static QrConfig initQrConfig(int width, int height) {
        QrConfig config = new QrConfig(width, height);
        // 设置边距,既二维码和背景之间的边距
        config.setMargin(3);
        // 设置前景色,既二维码颜色(青色)
        config.setForeColor(Color.black.getRGB());
        // 设置背景色(灰色)
        config.setBackColor(Color.white.getRGB());
        return config;
    }

    /**
     * 生成到文件
     *
     * @param content
     * @param filepath
     */
    public void createQRCode2File(String content, int width, int height, String filepath) {
        try {
            QrCodeUtil.generate(content, initQrConfig(width, height), FileUtil.file(filepath));
            log.info("生成二维码成功, 位置在:{}!", filepath);
        } catch (QrCodeException e) {
            log.error("发生错误! {}!", e.getMessage());
        }
    }

    /**
     * 生成到流
     *
     * @param content
     * @param response
     */
    public void createQRCode2Stream(String content, int width, int height, HttpServletResponse response) {
        try {
            QrCodeUtil.generate(content, initQrConfig(width,height), "png", response.getOutputStream());
            log.info("生成二维码成功!");
        } catch (QrCodeException | IOException e) {
            log.error("发生错误! {}!", e.getMessage());
        }
    }

3、编写模拟controller

@RestController
@Slf4j
public class QRCodeController {
    @Autowired
    private QRCodeService qrCodeService;

    /**
     * 生成流的形式的二维码
     * @param codeContent
     * @param response
     */
    @GetMapping("qrCode")
    public void getQRCode(String codeContent, int width, int height, HttpServletResponse response) {
        try {
            qrCodeService.createQRCode2Stream(codeContent, width, height, response);

            log.info("成功生成二维码!");
        } catch (Exception e) {
            log.error("发生错误, 错误信息是:{}!", e.getMessage());
        }
    }

    /**
     * 生成图片并存放到本地
     * @param codeContent
     */
    @GetMapping("qrCodeByFile")
    public void getQRCodeByFile(String codeContent, int width, int height) {
        String filePath="G:/RPC/erweima/first.png";
        try {
            qrCodeService.createQRCode2File(codeContent,width,height,filePath);
            log.info("成功生成二维码!");
        } catch (Exception e) {
            log.error("发生错误, 错误信息是:{}!", e.getMessage());
        }
    }

二、vue生成二维码

1、添加组件并引入

添加组件
npm install qrcodejs2 --save
引入
import QRCode from "qrcodejs2";

2、编写Html代码

<div ref="qrcode">
</div>

2、编写JS代码

//防止多次生成
document.getElementById("qrcode").innerHTML = "";
// 在属性ref="qrcode"的div里边添加二维码
new QRCode(this.$refs.qrcode, {
width: this.qrCode.qrwidth, // 宽度
height: this.qrCode.qrheight, // 高度
colorDark: "#000000", //二维码颜色
colorLight: "#ffffff", //背景颜色
text: this.qrCode.qrcontent,// 二维码内容(接口返回的数字或者什么,如:需要扫码跳转的链接)
});
posted @ 2021-09-22 17:44  __先森  阅读(114)  评论(0编辑  收藏  举报