问题:
原因:
Postman第一次发送请求和第二次发送请求不是同一个Session对象。
解决办法:
在第一次请求时,将Sessionid(第一张图黑框),复制到第二次请求的Headers中,KEY为Cookie。
保证两次的请求是同一个Session,则可以获取到Session中的值。
输入的验证码与生成的验证码不匹配
验证码请求代码
@RestController public class ValidateCodeController { @RequestMapping(value = "/validateCode") public JsonRESTResult validate(HttpSession session, HttpServletRequest request, HttpServletResponse response)throws Exception{ JsonRESTResult jsonRESTResult = new JsonRESTResult(); //利用图片工具生成图片 //第一个参数是生成的验证码,第二个参数是生成的图片 Object[] objs = ImageUtil.createImage(); //将验证码存入Session session.setAttribute("imageCode",objs[0]); System.out.println("验证码:"+session.getAttribute("imageCode")); //将图片输出给浏览器 BufferedImage image = (BufferedImage) objs[1]; response.setContentType("image/png"); OutputStream os = response.getOutputStream(); ImageIO.write(image, "png", os); jsonRESTResult.setCode(JsonRESTResultMsg.CODE_800.getCode()); jsonRESTResult.setMsg("生成验证码成功"); jsonRESTResult.setData(objs[0]); return jsonRESTResult; } } |
登录请求代码
@RestController @RequestMapping(value = "/login") public class LoginController { @Resource private LoginService loginService; /** * @author zdj * @create 2018/12/19/019 16:44 * @param @validateCode: 用户输入的验证码 **/ @RequestMapping(value = "/logon" ,method= RequestMethod.POST) public JsonRESTResult getUserInfo(HttpSession session, String userName, String password, String validateCode){ JsonRESTResult jsonRESTResult = new JsonRESTResult(); String code = (String)session.getAttribute("imageCode"); System.out.println("系统生成的验证码为:"+code); //判断用户输入的验证码与系统生成的验证码是否一致 if(validateCode.equals(code)){ //判断是否有该对应的用户 User user = loginService.findUser(userName,password); if (user !=null){ jsonRESTResult.setCode(JsonRESTResultMsg.CODE_800.getCode()); jsonRESTResult.setMsg("登录成功"); jsonRESTResult.setData(user); return jsonRESTResult; }else{ jsonRESTResult.setCode(JsonRESTResultMsg.CODE_500.getCode()); jsonRESTResult.setMsg("登录失败,用户名密码错误"); jsonRESTResult.setData(null); return jsonRESTResult; } }else{ jsonRESTResult.setCode(JsonRESTResultMsg.CODE_500.getCode()); jsonRESTResult.setMsg("验证码错误"); jsonRESTResult.setData(null); return jsonRESTResult; } } } |
验证码工具类
package com.neusiri.epcstest.util; import javax.imageio.ImageIO; import java.awt.*; import java.awt.image.BufferedImage; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStream; import java.util.Random; public class ImageUtil { // 验证码字符集 private static final char[] chars = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'}; // 字符数量 private static final int SIZE = 4; // 干扰线数量 private static final int LINES = 5; // 宽度 private static final int WIDTH = 80; // 高度 private static final int HEIGHT = 30; // 字体大小 private static final int FONT_SIZE = 30; /** * 生成随机验证码及图片 * Object[0]:验证码字符串; * Object[1]:验证码图片。 */ public static Object[] createImage() { StringBuffer sb = new StringBuffer(); // 1.创建空白图片 BufferedImage image = new BufferedImage( WIDTH, HEIGHT, BufferedImage.TYPE_INT_RGB); // 2.获取图片画笔 Graphics graphic = image.getGraphics(); // 3.设置画笔颜色 graphic.setColor(Color.LIGHT_GRAY); // 4.绘制矩形背景 graphic.fillRect(0, 0, WIDTH, HEIGHT); // 5.画随机字符 Random ran = new Random(); for (int i = 0; i <SIZE; i++) { // 取随机字符索引 int n = ran.nextInt(chars.length); // 设置随机颜色 graphic.setColor(getRandomColor()); // 设置字体大小 graphic.setFont(new Font( null, Font.BOLD + Font.ITALIC, FONT_SIZE)); // 画字符 graphic.drawString( chars[n] + "", i * WIDTH / SIZE, HEIGHT*2/3); // 记录字符 sb.append(chars[n]); } // 6.画干扰线 for (int i = 0; i < LINES; i++) { // 设置随机颜色 graphic.setColor(getRandomColor()); // 随机画线 graphic.drawLine(ran.nextInt(WIDTH), ran.nextInt(HEIGHT), ran.nextInt(WIDTH), ran.nextInt(HEIGHT)); } // 7.返回验证码和图片 return new Object[]{sb.toString(), image}; } /** * 随机取色 */ public static Color getRandomColor() { Random ran = new Random(); Color color = new Color(ran.nextInt(256), ran.nextInt(256), ran.nextInt(256)); return color; } public static void main(String[] args) throws IOException { Object[] objs = createImage(); BufferedImage image = (BufferedImage) objs[1]; OutputStream os = new FileOutputStream("D:/1.png"); ImageIO.write(image, "png", os); os.close(); } } |
本文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理