【转】Struts2 图形验证码

 package com.gsj.action;

import java.io.*;
import javax.imageio.ImageIO;
import javax.imageio.stream.ImageOutputStream;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;

import java.awt.*;
import java.awt.image.BufferedImage;
//DefaultAction类继承了ActionSupport 并定义了session变量
public class CreateValidateAction extends ActionSupport {

    /**
  *
  */
 private static final long serialVersionUID = 1L;
 private ByteArrayInputStream inputStream;
    //产生四个0~9的随机数,放在一个字符串里
    public String createRandomString() {
        String str = "";
        for (int i = 0; i < 4; i++) {
            str += Integer.toString((new Double(Math.random() * 10)).intValue());
        }
        return str;
    }
    //随机产生一个颜色
    public Color createsRandomColor() {
        int r = (new Double(Math.random() * 256)).intValue();
        int g = (new Double(Math.random() * 256)).intValue();
        int b = (new Double(Math.random() * 256)).intValue();
        return new Color(r, g, b);
    }
    //生成一个内存图片,将四个随机数写在图片上
    public BufferedImage createImage(String str) {
        int width = 60;
        int height = 22;
        BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
        // 获取图形上下文
        Graphics g = image.getGraphics();
        // 设定背景色
        g.setColor(Color.WHITE);
        g.fillRect(0, 0, width, height);
        //画边框
        g.setColor(Color.black);
        g.drawRect(0, 0, width - 1, height - 1);
        // 将认证码显示到图象中
        g.setFont(new Font("Atlantic Inline", Font.PLAIN, 18));
        //使用随机颜色
        g.setColor(this.createsRandomColor());
        //将随机字符串的每个数字分别写到图片上
        g.drawString(Character.toString(str.charAt(0)), 8, 17);
        g.drawString(Character.toString(str.charAt(1)), 20, 17);
        g.drawString(Character.toString(str.charAt(2)), 33, 17);
        g.drawString(Character.toString(str.charAt(3)), 45, 17);
        // 图象生效
        g.dispose();
        return image;
    }
    //将图片的以字节形式写到InputStream里
    public ByteArrayInputStream createInputStream() throws Exception {
        //获取随机字符串
        String str=this.createRandomString();
        BufferedImage image = this.createImage(str);
        //将产生的字符串写入session,供校验时使用
        ServletActionContext.getRequest().getSession().setAttribute("validateCode", str);
        ByteArrayOutputStream output = new ByteArrayOutputStream();
        ImageOutputStream imageOut = ImageIO.createImageOutputStream(output);
        ImageIO.write(image, "JPEG", imageOut);
        imageOut.close();
        ByteArrayInputStream input = new ByteArrayInputStream(output.toByteArray());
        output.close();
        return input;
    }

    @Override
    public String execute() throws Exception {
        setInputStream(createInputStream());
        return SUCCESS;
    }
    
    public ByteArrayInputStream getInputStream() {
        return inputStream;
    }
    public void setInputStream(ByteArrayInputStream inputStream) {
        this.inputStream = inputStream;
    }
}

-----------------------------------------------------------------------------------------------------------------------------------------------------------

struts.xml

<!-- 产生随机验证码 --> 
        <action name="createValidateAction" class="createValidateAction">
            <result type="stream">
                <param name="contentType">image/jpeg</param>
                <param name="inputName">inputStream</param>
            </result>
        </action>

---------------------------------------------------------------------------------------------------------------------------------------------------------------

页面

<tr>
        <td height="30" align="center">验证码</td>
        <td><input name="yzm" type="text" id="yzm" size="10" />&nbsp;&nbsp;&nbsp;<img src="createValidateAction.action" alt="看不清,再换一张?" style="cursor: hand;" align="absmiddle" onClick="changeValidateCode(this)"/></td>
</tr>
----------------------------------------------------------------------------------------------------------------------------------------------------------------

验证码 在服务器端验证,所以不能在 验证码 所在页用JS验证 session中的验证码 会和 图片中的不一致。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一个基于struct2的登陆实现,大致思路如下: 1.前端页面设计:设计一个登陆页面,包括用户名、密码、验证码等输入框,以及一个“登陆”按钮。 2.验证码实现:为了防止恶意攻击,可以在页面中添加一个验证码输入框,用户需要输入正确的验证码才能进行登陆。验证码可以使用Java图形界面技术生成,并存储在Session中。 3.数据库表设计:创建一个用户表,用于存储用户的登录信息,包括用户名、密码、邮箱等字段。 4.后端代码实现:使用struct2框架编写Action类,并编写一个登陆方法,该方法需要从前端获取输入的用户名、密码、验证码等信息,并检查这些信息是否合法,如果合法则查询数据库,检查用户名和密码是否匹配,如果匹配,则将用户信息存储在Session中,并跳到主页面。 以下是一个简单的实现代码示例: 1.前端页面设计:login.jsp <html> <head> <title>用户登陆</title> </head> <body> <form action="loginAction" method="post"> 用户名: <input type="text" name="username" id="username" /><br /> 密码: <input type="password" name="password" id="password" /><br /> 验证码: <input type="text" name="verifyCode" id="verifyCode" /><br /> <img src="verifyCode" id="verifyCodeImg" /> <a href="#" onclick="document.getElementById('verifyCodeImg').src='verifyCode?rnd='+Math.random();">看不清,换一张</a><br /> <input type="submit" value="登陆" /><br /> </form> </body> </html> 2.验证码实现:verifyCode.jsp <%@ page import="java.awt.*, java.awt.image.*, java.util.*, javax.imageio.*, java.io.*" %> <% response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setDateHeader("Expires", 0); int width=90, height=40; 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)); g.setColor(getRandColor(160,200)); for (int i=0;i<155;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 = {"1","2","3","4","5","6","7","8","9","0","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"}; String code = ""; for (int i = 0; i < 4; i++) { String str = codes[random.nextInt(codes.length)]; code += str; g.setColor(new Color(20+random.nextInt(110),20+random.nextInt(110),20+random.nextInt(110))); g.drawString(str,13*i+15,25); } session.setAttribute("verifyCode", code); g.dispose(); ImageIO.write(image, "JPEG", response.getOutputStream()); 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); } %> 3.数据库表设计:User CREATE TABLE User( user_id int(11) NOT NULL auto_increment, username varchar(20) NOT NULL, password varchar(32) NOT NULL, email varchar(50) default NULL, PRIMARY KEY(user_id) ); 4.后端代码实现:LoginAction.java public class LoginAction extends ActionSupport { private String username; private String password; private String verifyCode; public String execute() throws Exception { if (!verifyCode.equalsIgnoreCase((String)session.getAttribute("verifyCode"))) { addFieldError("verifyCode", "验证码输入错误"); return INPUT; } Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { conn = DriverManager.getConnection("jdbc:mysql://localhost/test", "root", "password"); pstmt = conn.prepareStatement("SELECT * FROM User WHERE username=? AND password=?"); pstmt.setString(1, username); pstmt.setString(2, password); rs = pstmt.executeQuery(); if (rs.next()) { User user = new User(); user.setUsername(rs.getString("username")); user.setPassword(rs.getString("password")); user.setEmail(rs.getString("email")); session.setAttribute("user", user); return SUCCESS; } else { addActionError("用户名或密码错误"); return INPUT; } } catch (SQLException ex) { System.out.println(ex.getMessage()); addActionError("数据库连接失败"); return INPUT; } finally { if (rs != null) rs.close(); if (pstmt != null) pstmt.close(); if (conn != null) conn.close(); } } // Getters and setters // ... } 另外,还需要在struts.xml中配置Action映射: <package name="default" extends="struts-default"> <action name="loginAction" class="com.example.LoginAction"> <result name="success">/index.jsp</result> <result name="input">/login.jsp</result> </action> </package> 以上代码仅供参考,还需要进行优化和完善。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值