vue+spring boot校验码的实现

今天是个好日子,用vue写了一个校验码来玩玩,样子如下:
在这里插入图片描述
1.img标签

<img
              style="height:40px; width: 100px; cursor: pointer;"
              ref="imgIdentifyingCode"
              :src="selectedLogoPicture.imgUrl"
              class="logoImg"
            >

2.js代码

/**
     * 获取校验码
     */
    getIdentifyingCode() {
      let selft = this;
      //let pic = this.$refs.imgIdentifyingCode
      selft.loadingChack = true;
      let uuid = Utils.getUuid(32, 16);
      this.$store.state.uuid = uuid;
      this.$api.reader.getVerify(
        { responseType: "arraybuffer", uuid: uuid },
        r => {
          selft.loadingChack = false;
          selft.selectedLogoPicture.imgUrl = "data:image/png;base64," + r;
        }
      );
    },

3.controller

@RequestMapping("/getVerify")
	public void getVerify(@RequestParam String uuid, HttpServletRequest request, HttpServletResponse response) {
		response.setContentType("image/jpeg");// 设置相应类型,告诉浏览器输出的内容为图片
		response.setHeader("Pragma", "No-cache");// 设置响应头信息,告诉浏览器不要缓存此内容
		response.setHeader("Cache-Control", "no-cache");
		response.setDateHeader("Expire", 0);
		userService.getRandcodedDawTransparent(uuid, request, response);// 输出验证码图片方法
	}

4.service

@Override
	public void getRandcodedDawTransparent(String uuid, HttpServletRequest request, HttpServletResponse response) {
		try {
			Map<String, Object> map = CodeUtil.getRandcodedDawTransparent();
			// 将生成的随机字符串保存到session中
			log.info("==保存的uuid:"+uuid);
			log.info("==保存的code:"+map.get("code"));
			sessionUtil.saveCode(uuid, map.get("code"));

			response.setContentType("image/png");
			OutputStream out = response.getOutputStream();

			out.write((byte[]) map.get("img"));
			out.flush();
			out.close();
		} catch (IOException e) {
			log.error(e.getMessage());
		}
	}

5.util

public static Map<String, Object> getRandcodedDawTransparent() throws IOException {
		Map<String, Object> rsMap = new HashMap<>();
		// 创建BufferedImage对象
		BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
		// 获取Graphics2D
		Graphics2D g2d = image.createGraphics();

		// 增加下面代码使得背景透明
		image = g2d.getDeviceConfiguration().createCompatibleImage(width, height, Transparency.TRANSLUCENT);
		g2d.dispose();
		g2d = image.createGraphics();

		g2d.setFont(new Font("Times New Roman", Font.ROMAN_BASELINE, 18));// 字体大小
		g2d.setColor(getRandColor(110, 133));// 字体颜色

		// 绘制干扰线
		for (int i = 0; i <= lineSize; i++) {
			drowLine(g2d, width, height);
		}
		// 绘制随机字符
		String randomString = "";
		for (int i = 1; i <= stringNum; i++) {
			randomString = drowString(g2d, randomString, i);
		}
		log.info(randomString);
		rsMap.put("code", randomString);
		g2d.dispose();
		ByteArrayOutputStream baos = new ByteArrayOutputStream();// io流
		ImageIO.write(image, "png", baos);// 写入流中
		byte[] bytes = baos.toByteArray();// 转换成字节
		bytes = Base64.encodeBase64(bytes);
		rsMap.put("img", bytes);

		return rsMap;
	}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
学生管理系统是一个常见的项目,可以使用Spring Boot作为后端框架,Vue作为前端框架,MySQL作为数据库。下面是一个简单的实现步骤: 1. 创建数据库表结构: - 学生表:包含学生的ID、姓名、年龄、性别等信息。 - 可以使用MySQL Workbench或者命令行创建表结构。 2. 创建Spring Boot项目: - 使用Spring Initializr创建一个新的Spring Boot项目,添加必要的依赖。 - 配置数据库连接信息,包括URL、用户名和密码等。 3. 创建学生实体类: - 在Spring Boot项目中创建一个学生实体类,包含与数据库表对应的属性。 4. 创建学生Controller: - 创建一个RESTful API的Controller类,处理学生相关的HTTP请求。 - 使用Spring注解标记Controller类和接口方法。 5. 创建学生Service: - 创建一个Service类,处理业务逻辑,例如增删改查学生信息。 - 使用@Autowired注解将Service类注入到Controller中。 6. 创建Vue前端项目: - 使用Vue CLI创建一个新的Vue项目,配置路由和组件等。 - 可以使用Element UI等UI库来美化界面。 7. 编写前端页面: - 创建学生列表、添加学生、编辑学生等页面,使用axios发送HTTP请求与后端交互。 8. 测试运行: - 启动Spring Boot项目和Vue项目,测试学生管理系统的功能。 这只是一个简单的实现示例,实际项目中可能还需要加入权限控制、分页查询、数据校验等功能。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值