“This is the 15th day of my participation in the First Challenge 2022. For details: First Challenge 2022.”
Previously said Java generation of TWO-DIMENSIONAL code background implementation, but the actual application can not just use Java background to generate two-dimensional code, using Java to generate two-dimensional code will generally do the Web side, this film introduces the generation of two-dimensional code front-end implementation and background code modification.
The final result
Enter characters in the text box, click the button to generate TWO-DIMENSIONAL code, invoke the background interface to generate two-dimensional code and return the two-dimensional code string base64. Add the information in the string to the attribute of IMG label SRC to display the two-dimensional code picture.
Front-end code implementation
Vue file code
Mainly to achieve the function of the main, did not do any layout and beautification
<template> <div> <input type="text" v-model="qrCodeText"> <button type="button" @click="clickGetCode()"> <img :src="'data:image/png; base64,'+ this.base64QrCode" style="width: 20vw;" > </div> </template> <script> import {getQrCode} from '@/ API /downloadDoc/index' export default {name: 'QrCode', data () {return {qrCodeText: ', base64QrCode: '}}, // 2, add custom component components: }, // Create () {}, methods: {clickGetCode () {// Call the background interface to generate the QR code getQrCode(this.qrcodeText).then(data => {// The returned string is assigned to the SRC attribute binding variable this.base64qrCode = data }) } } } </script> <style>Copy the code
Request background code
import request from '.. Export function getQrCode (qrCodeText) {return request({url: '/ Ming /getQrCode? qrCodeText=' + qrCodeText, method: 'get' }) }Copy the code
Back-end code implementation
For the implementation of back-end code, please refer to the previous article: Java generates TWO-DIMENSIONAL code pictures, and turns to Base64-nuggets (juejin. Cn).
It should be noted that the previous article is directly written hard coding, here is the need to provide interface to the front end, before is introduced two methods to generate two-dimensional code, here needs to use the first method to base64 after returning the string to the front end.
The following is the modified code for reference:
@RequestMapping("/getQrCode") public String getQrCode(@RequestParam String qrCodeText){ String base64 = ""; String QrCodeStr = qrCodeText; Try {Map<EncodeHintType, String> charcter = new HashMap<>(); // Set character set charcter.put(EncodeHintType.CHARACTER_SET, "UTF-8"); // A string to be generated to set the four parameters of the TWO-DIMENSIONAL code. The type is set to two-dimensional code, width of two-dimensional code, height of two-dimensional code, BitMatrix = new MultiFormatWriter().encode(QrCodeStr, barcodeformat.qr_code, 500, 500, charcter); 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; SetRGB (x, y, bitmatrix.get (x, y)? BLACK : WHITE); Base64 ByteArrayOutputStream stream = new ByteArrayOutputStream(); // Set the image format imageio. write(image, "PNG ", stream); Encode (stream.tobytearray ()); encode(stream.tobytearray ()); } catch (Exception e) { e.printStackTrace(); } return base64; }Copy the code