SpringBoot简单项目(二维码扫描)

pom.xml中导入依赖

 <!-- zxing -->
        <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>

前端网页

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>二维码生成</title>
</head>
<body>
<h1>二维码生成</h1>
<input type="text" id="textInput" placeholder="输入内容">
<button onclick="generateQRCode()">生成二维码</button>
<div id="qrCodeContainer"></div>

<script>
    function generateQRCode() {
        const text = document.getElementById('textInput').value;
        const qrCodeContainer = document.getElementById('qrCodeContainer');
        qrCodeContainer.innerHTML = '';

        if (text) {
            fetch(`/generateQRCode?text=${encodeURIComponent(text)}`)   //调用了generateQRCode方法生成二维码
                .then(response => response.blob())   //返回时用blob()格式  因为要用二进制形式存储二维码
                .then(blob => {
                    const img = document.createElement('img');  //创建img元素
                    img.src = URL.createObjectURL(blob);  //给Img元素添加src
                    qrCodeContainer.appendChild(img);   //将img添加到qrCodeContainer标签中
                });
        }
    }
</script>
</body>
</html>

控制器

package com.qcby.Controller;



import com.google.zxing.BarcodeFormat;
import com.google.zxing.WriterException;
import com.google.zxing.client.j2se.MatrixToImageWriter;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.QRCodeWriter;
import com.google.zxing.qrcode.encoder.QRCode;

import org.springframework.core.io.ByteArrayResource;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.io.ByteArrayOutputStream;
import java.io.IOException;

@RestController
public class QRCodeController {

    @GetMapping("/generateQRCode")
    public ResponseEntity<ByteArrayResource> generateQRCode(@RequestParam String text) {
        QRCodeWriter qrCodeWriter = new QRCodeWriter();
        ByteArrayOutputStream outputStream = new ByteArrayOutputStream();

        try {
            BitMatrix qrCode = qrCodeWriter.encode(text, BarcodeFormat.QR_CODE, 200, 200); //encode方法  将text转换为你想要的格式
            MatrixToImageWriter.writeToStream(qrCode, "PNG", outputStream);
            //qrCode: 这是一个 BitMatrix 对象,它包含了生成的二维码数据。这个对象是通过 QRCodeWriter.encode 方法生成的。
            //"PNG": 这是图像的格式类型。在这里,我们指定将二维码图像编码为 PNG 格式。
            //outputStream: 这是一个 ByteArrayOutputStream 对象,用于存储编码后的图像数据。
            //MatrixToImageWriter 是 ZXing 库中的一个实用工具类,用于将 BitMatrix 对象转换为图像。writeToStream 方法将 BitMatrix 对象表示的二维码图像写入到指定的输出流中。
        } catch (WriterException | IOException e) {
            return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
        }

        ByteArrayResource resource = new ByteArrayResource(outputStream.toByteArray());  //将输出流的数据读取

        return ResponseEntity.ok()   //表示 HTTP 响应的状态码是 200 OK
                .header(HttpHeaders.CONTENT_TYPE, MediaType.IMAGE_PNG_VALUE)  //表示返回数据的形式是PNG
                .contentLength(resource.contentLength())  //表示返回数据的长度
                .body(resource); //将数据返回
    }
}

这里注意下,如果你是用手机扫码的话,手机很多应用是配有自动扫描的就i不需要下面扫描的代码了

package com.qcby.Controller;

import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class QRCodeScanController {

    @PostMapping("/scanQRCode")
    public ResponseEntity<String> handleQRCodeScan(@RequestBody String scannedData) {
        // 处理扫描的数据
        return ResponseEntity.ok("Scanned data: " + scannedData);
    }
}

补充: 

Spring Boot项目中实现二维码登录功能,通常涉及到以下几个步骤: 1. **集成第三方库**:首先,需要添加二维码生成库,如Qrcode4j、Apache Commons Imaging等。例如,添加Qrcode4j依赖到pom.xml文件: ```xml <dependency> <groupId>com.google.zxing</groupId> <artifactId>javase</artifactId> <version>3.4.1</version> </dependency> ``` 2. **生成二维码**:使用Qrcode4j或类似库创建包含认证信息的二维码,可以将用户的token或者其他验证数据编码成二维码图片。 ```java // 示例代码 QrcodeBean qrcodeBean = new QrcodeBean(); qrcodeBean.setTitle("Spring Boot QR Login"); qrcodeBean.setCode("your-token-or-auth-code"); // 将实际的token放入这里 String qrCodePath = QRCodeUtil.encode(qrcodeBean); ``` 3. **展示二维码**:将生成的二维码图片路径返回给前端展示,用户通过扫描获取登录链接或直接访问该URL进行验证。 4. **处理扫码结果**:在前端,当用户扫描二维码后,会跳转到一个预设的地址(可能是一个特定的Controller处理)。在这个地方,你需要解析传入的code并验证其有效性,如果验证通过则登录成功,否则提示错误。 5. **登录逻辑**:在后台服务中,可以设置一个对应的Controller方法来处理这个逻辑,并在数据库或令牌存储中查找匹配的用户信息。 ```java @PostMapping("/login/qr") public String handleQrLogin(@RequestParam("code") String code) { // 验证code的有效性... if (isValidCode(code)) { return "loginSuccess"; } else { return "loginFailed"; } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值