Java学习-huTool二维码学习
我们先创建一个Springboot项目
目录如下:
因为我这个项目是一个多模块的项目而且已经链接了数据库,这些都不重要,我们值看二维码的部分就可以了。
配置pom.xml文件
首先我们要引入huTool的maven文件
<!--huTool工具-->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.3</version>
</dependency>
其次我们在查看huTool官网的时候,他说:
考虑到Hutool的非强制依赖性,因此zxing需要用户自行引入:
我们在引入google.zxing
<dependency>
<groupId>com.google.zxing</groupId>
<artifactId>core</artifactId>
<version>3.3.3</version>
</dependency>
然后我们直接写测试代码
package com.example.demoqrcode;
import cn.hutool.extra.qrcode.QrCodeUtil;
import cn.hutool.extra.qrcode.QrConfig;
import com.example.democommon.contasant.CommonConstant;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.io.IOException;
/**
* @version 1.0.0
* @className: IndexController
* @description:
* @author: zhangjunfa
* @date: 2022/6/14 9:10
*/
@RestController
public class QrCodeController {
/**
* 获取二维码,输出流
*/
@GetMapping(value = "/getQrCode")
public void getQrCode(HttpServletResponse response) throws IOException {
QrConfig config = new QrConfig(CommonConstant.DEFAULT_WIDTH, CommonConstant.DEFAULT_HEIGHT);
// 设置边距,既二维码和背景之间的边距
config.setMargin(3);
// 设置前景色,既二维码颜色(青色)
config.setForeColor(Color.BLACK);
// 设置背景色(灰色)
config.setBackColor(Color.WHITE);
// 高纠错级别
config.setErrorCorrection(ErrorCorrectionLevel.H);
byte[] image = QrCodeUtil.generatePng(CommonConstant.QRCODE_CONTENT, config);
response.setHeader("Cache-Control", "no-store");
response.setHeader("Pragma", "no-cache");
response.setDateHeader("Expires", 0);
response.setContentType(CommonConstant.CONTENT_TYPE);
ServletOutputStream sout = response.getOutputStream();
sout.write(image);
sout.flush();
sout.close();
}
}
在写一个HTML页面,用来做请求
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.w3.org/1999/html">
<head>
<meta charset="UTF-8">
<title>Success</title>
</head>
<body>
<h1 style="color: limegreen">二维码 - Success</h1>
<hr/>
<img src="/getQrCode" alt="二维码">
</body>
</html>
然后我们在页面中请求看一下
完美!!!
全部学习案例都在:Gitte点击
都是学习的,不喜勿喷啊!(灬ꈍ ꈍ灬) 都是各大论坛上的代码。