struts2中的随机验证码实现
struts2实现验证码还是很方便的。struts确实给我们带来了很多的方便之处。
1:AuthCode.java是用来生成验证码图片的:
public class AuthCode {private ByteArrayInputStream input; private ByteArrayOutputStream output; private String code;// 验证码 private int codeNum;// 验证码字符数量 private int width; private int height; // 构造器 private AuthCode(int width, int height, int codeNum) { this.width = width; this.height = height; this.codeNum = codeNum; if (width < 15 * codeNum + 6) { this.width = 13 * codeNum + 6; } if (height < 20) { this.height = 20; } buildImage(); } // 以字符串形式返回验证码 public String getCode() { return code; } // 以输入流的形式返回验证图片 public ByteArrayInputStream getIamgeAsInputStream() { return input; } // 以输出流的形式返回验证图片 public ByteArrayOutputStream getImageAsOuputStream() { return output; } // 创建默认大小的验证码 public static AuthCode createInstance() { return new AuthCode(85, 20, 4); } // 创建指定大小的验证码 public static AuthCode createInstance(int width, int height, int codeNum) { return new AuthCode(width, height, codeNum); } // 生成验证码图片 private void buildImage() { BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); // 获取图形上下文 Graphics g = image.getGraphics(); // 生成随机类 Random random = new Random(); // 设定背景色 g.setColor(getRandColor(200, 250)); g.fillRect(0, 0, width, height); // 设定字体 g.setFont(new Font("Times New Roman", Font.PLAIN, 18)); // 随机产生150条干扰线,使图象中的认证码不易被其它程序探测到 g.setColor(getRandColor(160, 200)); for (int i = 0; i < 150; i++) { int x = random.nextInt(width); int y = random.nextInt(height); int xl = random.nextInt(12); int yl = random.nextInt(12); g.drawLine(x, y, x + xl, y + yl); } // 取随机产生的认证码 String codes = "ABCDEFGHJKLMNOPQRSTUVWXYZ23456789"; String sRand = ""; for (int i = 0; i < codeNum; i++) { String rand = codes.charAt(random.nextInt(codes.length())) + ""; sRand += rand; // 将认证码显示到图象中 g.setColor(new Color(20 + random.nextInt(110), 20 + random .nextInt(110), 20 + random.nextInt(110))); // 将字符串绘制到图片上 g.drawString(rand, i * (width / codeNum) + 6, (int)((height+12)/2)); } /* 验证码赋值 */ this.code = sRand; // 图象生效 g.dispose(); try { output = new ByteArrayOutputStream(); ImageOutputStream imageOut = ImageIO .createImageOutputStream(output); ImageIO.write(image, "JPEG", imageOut); imageOut.close(); input = new ByteArrayInputStream(output.toByteArray()); } catch (Exception e) { System.out.println("验证码图片产生出现错误:" + e.toString()); } } // 获取随机颜色 private Color getRandColor(int fc, int bc) { Random random = new Random(); if (fc > 255) fc = 255; if (bc > 255) bc = 255; int r = fc + random.nextInt(bc - fc); int g = fc + random.nextInt(bc - fc); int b = fc + random.nextInt(bc - fc); return new Color(r, g, b); } }
下面的是action中的调用方法:
public InputStream getInputStream(){AuthCode code = AuthCode.createInstance();HttpServletRequest request = ServletActionContext.getRequest();HttpSession seesion = request.getSession();//session.put("authCode", code.getCode());seesion.setAttribute("authcode", code.getCode());return code.getIamgeAsInputStream();}public String execute(){return "success";}
?上面代码将生成的code放入session中了,这样在验证的时候就可以进行equals了。在action对应的.xml文件中得设置struts提供的stream模式来处理result
<action name="authcode" method="execute"> <result name="success" type="stream"><param name="contentType">image/jpeg</param> </result></action>
?然后还要在使用验证码图片的页面上添加链接:
<tr> <td width="13%" height="35" ><span colspan="2" name="authCode" type="text" value="" maxLength="4" size="10"> <img src="authcode.action" alt="struts2中的随机验证码兑现" style="cursor:hand" title="看不清楚?换一张" onclick="changeImage(this)"/> <label name="code">public String login(){String flag = "";HttpServletRequest request = ServletActionContext.getRequest();HttpSession session = request.getSession();String code = (String) session.getAttribute("authcode");if(authCode != null & authCode.toUpperCase().equals(code)){if(pd.queryLogin(power.getUserName(), power.getPassword()) == true){//session.put("power",power);power = pd.queryByName(power.getUserName());session.setAttribute("power", power);System.out.println(pd.queryByName(power.getUserName()).getPowerset());if((pd.queryByName(power.getUserName()).getPowerset()).equals("1111")){flag = "admin";System.out.println(flag);}else{flag = "adminlimit";System.out.println(flag);}}else{flag = "fail";}}else{authcode_msg = "验证码错误";flag = "error";}return flag;}
?
?