So here is a simple example just so we can compare how things differ in HTML versus JSP, does remind me of JSF / Viewlets to be honest.
1. Let start with what our simple project looks like in IntelliJ
2. The web.xml is defined as follows
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>Spring MVC Application</display-name>
<servlet>
<servlet-name>mvc-dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mvc-dispatcher</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3. The spring context XML is defined as follows
WEB-INF/mvc-dispatcher-servlet.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<context:component-scan base-package="pivotal.au.pas.springapp.mvc"/>
<bean id="templateResolver"
class="org.thymeleaf.templateresolver.ServletContextTemplateResolver">
<property name="prefix" value="/WEB-INF/resources/templates/" />
<property name="suffix" value=".html" />
<property name="templateMode" value="HTML5" />
</bean>
<bean id="templateEngine"
class="org.thymeleaf.spring3.SpringTemplateEngine">
<property name="templateResolver" ref="templateResolver" />
</bean>
<bean class="org.thymeleaf.spring3.view.ThymeleafViewResolver">
<property name="templateEngine" ref="templateEngine" />
</bean>
</beans>
4. Now the PeopleController.java class looks just like it would when rendering a JSP page view and so it should all we have done here is change what the view page will be which in this case is HTML itself. I have created some mock up data , rather then connecting to a RDBMS here.
package pivotal.au.pas.springapp.mvc;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import pivotal.au.pas.springapp.beans.Person;
import java.util.ArrayList;
import java.util.List;
@Controller
public class PeopleController
{
private static List<Person> people = null;
static
{
people = new ArrayList<Person>();
people.add(new Person(1, "pas"));
people.add(new Person(2, "lucia"));
people.add(new Person(3, "lucas"));
people.add(new Person(4, "siena"));
}
@RequestMapping("/showallpeople")
public String showallpeople(Model model)
{
model.addAttribute("people", people);
return "people";
}
}
5. The view page is just a HTML page as follows
WEB-INF/resources/templates/people.html
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
<title>Spring MVC with Thymeleaf - All people</title>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
</head>
<body>
<h2> Spring MVC with Thymeleaf - All people </h2>
<table border="1">
<thead>
<tr>
<th>Id#</th>
<th>Name</th>
</tr>
</thead>
<tbody>
<tr th:each="var : ${people}">
<td th:text="${var.id}"></td>
<td th:text="${var.name}"></td>
</tr>
</tbody>
</table>
<br />
<hr />
<br />
<address>
<a href="mailto:papicella@gopivotal.com">Pas Apicella</a>
</address>
</body>
</html>
6. So here is a simple JSP page as the entry page, could of been a HTML page.
index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Spring MVC with Thymeleaf</title>
</head>
<body>
<h2>Spring MVC with Thymeleaf</h2>
<ul>
<li><a href="/greeting">Greeting</a></li>
<li><a href="/showallpeople">Show All People</a></li>
</ul>
<hr />
<br />
<address>
<a href="mailto:papicella@gopivotal.com">Pas Apicella</a>
</address>
</body>
</html>
7. Run index.jsp
8. Finally when run and I click on "Show All People" link we get display as follows
More Information
http://spring.io/guides/gs/serving-web-content/
http://www.thymeleaf.org/index.html


No comments:
Post a Comment