Java 如何检查密码是否超过一年?

Java 如何检查密码是否超过一年?,java,mysql,jsp,servlets,Java,Mysql,Jsp,Servlets,我正在尝试在MVC中使用JSP开发用户登录/注册。该程序将做一个简单的登录,为用户创建和更新。在模型部分中,我应该根据以下条件返回0、1、2、3 如果用户验证成功,则返回0 1如果用户已成功验证,但密码较弱 2如果用户已成功验证,但密码已过期(超过1年) 3如果用户未经验证 这是我到目前为止所做的验证方法的代码 public int Validate() { try { Class.forName(driverName).newInstance();

我正在尝试在MVC中使用JSP开发用户登录/注册。该程序将做一个简单的登录,为用户创建和更新。在模型部分中,我应该根据以下条件返回0、1、2、3

如果用户验证成功,则返回0 1如果用户已成功验证,但密码较弱 2如果用户已成功验证,但密码已过期(超过1年) 3如果用户未经验证

这是我到目前为止所做的验证方法的代码

public int Validate() {

        try {
            Class.forName(driverName).newInstance();
        } catch (InstantiationException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (ClassNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        try {

            Connection connection = DriverManager.getConnection(dbURL,
                    username, password);

            String verifyQuery = "SELECT COUNT(email), dateSet, strength FROM users WHERE email=? AND hashPassword=SHA2(CONCAT(?, salt), 256)";
            PreparedStatement verify = connection.prepareStatement(verifyQuery);

            verify.setString(1, email);
            verify.setString(2, pass);
            ResultSet verified = verify.executeQuery();
            while (verified.next()) {
                if (verified.getInt(1) == 1) {
                    email_db = verified.getString(2);
                    pass_db = verified.getString(3);
                    date = verified.getDate(5);
                    strength = verified.getString(6);

                }
            }

        } catch (SQLException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        if (email_db.equals(email) && pass_db.equals(pass)) {
            status = 0;
        }
        if (email_db.equals(email) && pass_db.equals(pass)
                && strength.equals("weak")) {
            status = 1;
        }
        if (email_db.equals(email) && pass_db.equals(pass) && date> ){

        }
        return status;
    }

我对日期部分感到困惑,有什么建议吗?我是否应该为日期部分编写一个新方法?

我假设您从数据库中获得的日期是创建/上次修改密码的日期。在这种情况下,是否将a与今天的日期进行比较以获得不工作的天数? 检查并回答示例代码。

尝试下面的代码

java.util.Date lastDate = result.getTimestamp("date");
java.util.Date todaysDate = new java.util.Date(System.currentTimeMillis());

long days1 = lastDate.getTime()/(60*60*24*1000);
long days2 = todaysDate.getTime()/(60*60*24*1000);

long difference = days2-days1;

您可以使用此代码

if (email_db.equals(email) && pass_db.equals(pass) ){


Date dt = date;//Your Date from database 
Calendar passCreatedOn = Calendar.getInstance(); 
passCreatedOn.setTime(dt);


Calendar today=Calendar.getInstance();
Integer noOfDays=( (today.getTime() - passCreatedOn.getTime()) / (1000 * 60 * 60 * 24));
if(noOfDays>365)
{
    return 2
}
}   

使用普通Java,您可以使用
Java.util.Calendar
Java.util.Date
类来实现这一点。下面是一个函数的代码示例,该函数使用当前日期时间检查是否已过一年

public boolean hasPassedAYear(Date date) {
    long currentDate = Calendar.getInstance().getTimeInMillis();
    long dateToEval = date.getTime();
    // 1000 => milliseconds to seconds
    // 60 => seconds to minutes
    // 60 => minutes to hours
    // 24 => hours to days
    long days = (currentDate - dateToEval) / (1000 * 60  * 60 * 24);
    return days >= 365;
}
尽管如此,如果您想要一个好的代码(像所有人一样),您应该使用它来提供更好的日期/时间处理。这将是相同的函数,但使用Joda时间库:

public boolean hasPassedAYear(Date date) {
    DateTime currentDate = new DateTime();
    DateTime dateToEval = new DateTime(date);
    Interval interval = new Interval(dateToEval, currentDate);
    return interval.toPeriod().getYears() >= 1;
}

选择哪种方法取决于你。恕我直言,为了便于阅读、理解和维护,我会将代码与Joda Time一起使用。

为了计算两个日期之间的天数,我想避免使用库。@user2082191当然,这就是我首先添加纯Java解决方案的原因。事实上,我仍然认为使用Joda处理datetime操作会更好,正如您所看到的,Joda非常易于使用。另外,请注意,纯Java解决方案不做任何关于闰年(366天)的计算,而Joda Time已经处理了它。