Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

display Date diff in jsp

Tags:

jsp

jstl

I have a date field in database which store just date without time. Now I want to know the number of days difference in current date and my date field while displaying that in jsp page.

so I should have like

 databaseDate(2012-11-30) - currentDate(2012-11-27)  = 3 days
like image 601
Harry Avatar asked Nov 27 '12 16:11

Harry


1 Answers

There's nothing like that in standard JSTL. A custom EL function would be your best bet.

First implement some static methods which performs the job:

public final class Functions {

    private Functions() {}

    public static int daysBetween(Date before, Date after) {
        // ...
    }

    public static int daysUntilToday(Date date) {
        // ...
    }

}

If you register it as follows in /WEB-INF/functions.tld:

<?xml version="1.0" encoding="UTF-8" ?>
<taglib 
    xmlns="http://java.sun.com/xml/ns/javaee"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd"
    version="2.1">

    <tlib-version>1.0</tlib-version>
    <short-name>Custom_Functions</short-name>
    <uri>http://example.com/functions</uri>

    <function>
        <name>daysBetween</name>
        <function-class>com.example.Functions</function-class>
        <function-signature>boolean daysBetween(java.util.Date, java.util.Date)</function-signature>
    </function>
    <function>
        <name>daysUntilToday</name>
        <function-class>com.example.Functions</function-class>
        <function-signature>boolean daysUntilToday(java.util.Date)</function-signature>
    </function>
</taglib>

then you'll be able to use it as follows, provided that #{bean.date} returns a fullworthy java.util.Date:

<%@taglib uri="http://example.com/functions" prefix="f" %>

${f:daysUntilToday(bean.date)} days

The implementation is free to your choice. I'd personally prefer Joda Time:

public static int daysBetween(Date before, Date after) {
    return Days.daysBetween(new DateTime(before.getTime()), new DateTime(after.getTime())).getDays();
}

public static int daysUntilToday(Date date) {
    return Days.daysBetween(new DateTime(date.getTime()), new DateTime()).getDays();
}

Or if you're restricted to standard Java API, fall back to the well known Calendar boilerplate (unfortunately, JSR-310 didn't made it into Java 7, we've to wait for Java 8):

public static int daysBetween(Date before, Date after) {
    Calendar c1 = createCalendarWithoutTime(before);
    Calendar c2 = createCalendarWithoutTime(after);
    int days = 0;

    for (;c1.before(c2); days++) {
        c1.add(Calendar.DATE, 1);
    }

    return days;
}

public static int daysUntilToday(Date date) {
    return daysBetween(date, new Date());
}

private static Calendar createCalendarWithoutTime(Date date) {
    Calendar calendar = Calendar.getInstance();
    calendar.setTime(date);
    calendar.set(Calendar.HOUR_OF_DAY, 0);
    calendar.set(Calendar.MINUTE, 0);
    calendar.set(Calendar.SECOND, 0);
    calendar.set(Calendar.MILLISECOND, 0);
    return calendar;
}
like image 193
BalusC Avatar answered Nov 15 '22 09:11

BalusC