文章目录
- 前言
- 一、生成二维码
- 二、业务流程和代码逻辑梳理
- 总结
前言
使用框架 springboot 自己系统生成二维码,到前端网站,以及APP扫码登录流程,业务流程讲解梳理。也为自己做记录。
一、生成二维码
string content 参数表示 我要把一个什么字符串生成二维码 如:http:www.baidu.com 或者 uuid 任意字符串
pom.xml
<dependency>
<groupId>com.google.zxing</groupId>
<artifactId>core</artifactId>
<version>3.3.0</version>
</dependency>
<dependency>
<groupId>com.google.zxing</groupId>
<artifactId>javase</artifactId>
<version>3.3.0</version>
</dependency>
引入方法
import com.google.api.client.util.Base64;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.util.Hashtable;
/**
* 根据传入参数获取二维码
**/
public class CreateTwoCode {
public static String createQrCode(String content) throws Exception {
try (ByteArrayOutputStream out = new ByteArrayOutputStream()) {
Hashtable<EncodeHintType, Object> hints = new Hashtable<EncodeHintType, Object>();
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.H);
hints.put(EncodeHintType.CHARACTER_SET, "utf-8");
hints.put(EncodeHintType.MARGIN, 1);
BitMatrix bitMatrix = new MultiFormatWriter().encode(content, BarcodeFormat.QR_CODE, 400, 400, hints);
int width = bitMatrix.getWidth();
int height = bitMatrix.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, bitMatrix.get(x, y) ? 0xFF000000 : 0xFFFFFFFF);
}
}
ImageIO.write(image, "JPG", out);
return Base64.encodeBase64String(out.toByteArray());
}
}
}
二、业务流程和代码逻辑:
1. 后端生成二维码,生成二维码得规则可以是 随机得uuid,生成完二维码(图片得base64信息 ->上面提供得方法是生成二维码之后转为base64字符串)之后存储到redis (这里存储reids得 uuid是key 和 过期时间 预留出 value 后面有用),并设置过期时间。返回生成得二维码得base64 图片信息。
2.前端网页调用生成二维码接口,展示到界面。
3.后端提供查询接口 判断二维码是否过期接口和登录成功得接口 ,网页端间隔时间循环调用 查看是否过期。过期添加遮罩层提示二维码过期 点击刷新操作。
4.APP端扫描二维码(搜 zxing )读取到得信息 uuid,调用后台接口:验证二维码是否有效-或者已经被使用得逻辑在 第五步 。二维码,会出现多个手机同时扫描一个二维码得测试 .
5.APP 通过第四步返回 ok 提示 确认登录。调用后台接口 。这里存在得业务逻辑:APP能扫描 就表示用户已经在app登录了, 后台逻辑: 接收参数包括:(uuid ,用户登录 token) 通过uuid 从reids里拿出 然后将用户token放入value值中(这里,第四步可以通过这个value是否存在值判断 有没有被使用。)
6.网页端间隔时间循环调用接口 :返回成功 获取到用户token。后端逻辑: 通过uuid查询value中的值 然后返回。
完成。
总结
整套后端代码:我这边得逻辑是存在 A,B两个网页 和 A,B两个APP 公用得 之间调整和判断其实也是根据二维码得生成规则来的 可能对大家有不适合。有参考私聊吧。
提示:可以自己调整逻辑,上面只是举例 中间得业务逻辑和可能遇到得情况处理 。