2017-7-1 更新 spring 版本 4.3.9 更新mybatis 爲3.4.3css
0、先寫下文件結構防止配置放錯地方html
一、首先發下maven配置java
<properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version> <!--依賴版本--> <spring.version>4.3.9.RELEASE</spring.version> <mybatis.version>3.4.4</mybatis.version> <javax.servlet.version>3.1.0</javax.servlet.version> <freemarker.version>2.3.23</freemarker.version> <junit.version>4.12</junit.version> <mybatis-spring.version>1.3.1</mybatis-spring.version> <log4j2.version>2.8.2</log4j2.version> <slf4j.version>1.7.21</slf4j.version> <fastjson.version>1.2.35</fastjson.version> <guava.version>22.0</guava.version> <druid-version>1.0.31</druid-version> </properties> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-framework-bom</artifactId> <version>${spring.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <!--spring框架相關配置 begin--> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>${javax.servlet.version}</version> <scope>provided</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <exclusions> <exclusion> <groupId>commons-logging</groupId> <artifactId>commons-logging</artifactId> </exclusion> </exclusions> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> </dependency> <!--<dependency>--> <!--<groupId>com.fasterxml.jackson.core</groupId>--> <!--<artifactId>jackson-databind</artifactId>--> <!--<version>2.6.4</version>--> <!--</dependency>--> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>${fastjson.version}</version> </dependency> <!--spring框架相關配置 end--> <!--freemarker begin--> <dependency> <groupId>org.freemarker</groupId> <artifactId>freemarker</artifactId> <version>${freemarker.version}</version> </dependency> <!--freemarker end--> <!--orm and db begin--> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>${mybatis-spring.version}</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.42</version> <scope>runtime</scope> </dependency> <dependency> <groupId>com.microsoft.sqlserver</groupId> <artifactId>sqljdbc4</artifactId> <version>4.0</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>${druid-version}</version> </dependency> <!--orm and db end--> <!--日誌 begin--> <dependency> <!-- 橋接:告訴Slf4j使用Log4j2 --> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-slf4j-impl</artifactId> <version>${log4j2.version}</version> </dependency> <dependency> <!-- 橋接:告訴commons logging使用Log4j2 --> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-jcl</artifactId> <version>${log4j2.version}</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-api</artifactId> <version>${log4j2.version}</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-core</artifactId> <version>${log4j2.version}</version> </dependency> <dependency> <groupId>org.apache.logging.log4j</groupId> <artifactId>log4j-web</artifactId> <version>${log4j2.version}</version> </dependency> <!--日誌 end--> <dependency> <groupId>org.apache.commons</groupId> <artifactId>commons-lang3</artifactId> <version>3.6</version> </dependency> <!--工具包 begin--> <!--<dependency>--> <!--<groupId>org.apache.commons</groupId>--> <!--<artifactId>commons-collections4</artifactId>--> <!--<version>4.1</version>--> <!--</dependency>--> <!--<dependency>--> <!--<groupId>joda-time</groupId>--> <!--<artifactId>joda-time</artifactId>--> <!--<version>2.9.1</version>--> <!--</dependency>--> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>${guava.version}</version> </dependency> <!--工具包 end--> <!--測試包 begin--> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>${junit.version}</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <scope>test</scope> </dependency> <!--測試包 end--> </dependencies> <build> <!--<finalName>test</finalName>--> <plugins> <plugin> <groupId>org.mybatis.generator</groupId> <artifactId>mybatis-generator-maven-plugin</artifactId> <version>1.3.5</version> <executions> <execution> <id>Generate MyBatis Artifacts</id> <goals> <goal>generate</goal> </goals> </execution> </executions> </plugin> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.8</source> <target>1.8</target> <encoding>utf8</encoding> </configuration> </plugin> </plugins> </build>
簡單說明如下包的做用:mysql
spring-web 是對servlet的封裝 核心包web
spring-webmvc 是在spring-web的基礎上添加mvc支持 例如v層適配,這裏freemark模板引擎就用到了其中的 org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver類spring
spring-context-support 是對經常使用bean的擴展 其中 FreeMarkerConfigurer會依賴此包的 org.springframework.ui.freemarker.FreeMarkerConfigurationFactorysql
javax.servlet-api 是核心api這裏使用3.1express
spring-aspects 提供對AspectJ的支持apache
spring-tx 對事物支持 @Transactional 就在此包中json
spring-jdbc 對jdbc的封裝,方便spring管理jdbc 該項目中事物的管理即是使用了 org.springframework.jdbc.datasource.DataSourceTransactionManager
fastjson 這個包是用來處理返回json數據問題 來自阿里值得信賴
二、而後是 web.xml配置
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" version="3.1"> <!-- 區分項目名稱,防止默認重名 --> <context-param> <param-name>webAppRootKey</param-name> <param-value>maven.xxl_web.root</param-value> </context-param> <!-- 字符集 過濾器 --> <filter> <filter-name>CharacterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 設置Spring容器加載配置文件路徑 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext-*.xml</param-value> </context-param> <!-- Spring view分發器 --> <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/dispatcher-servlet.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> <!--攔截/*,這是一個錯誤的方式,請求能夠走到Action中,但轉到jsp時再次被攔截,不能訪問到jsp。 攔截/,restful風格 弊端:會致使靜態文件(jpg,js,css)被攔截後不能正常顯示。解決辦法看dispatcher--> </servlet-mapping> <!-- Spring會建立一個WebApplicationContext上下文,稱爲父上下文(父容器) ,保存在 ServletContext中,key是WebApplicationContext.ROOT_WEB_APPLICATION_CONTEXT_ATTRIBUTE的值。 可使用Spring提供的工具類取出上下文對象:WebApplicationContextUtils.getWebApplicationContext(ServletContext); DispatcherServlet是一個Servlet,能夠同時配置多個,每一個 DispatcherServlet有一個本身的上下文對象(WebApplicationContext),稱爲子上下文(子容器),子上下文能夠訪問父上下文中的內容, 但父上下文不能訪問子上下文中的內容。 它也保存在 ServletContext中,key是"org.springframework.web.servlet.FrameworkServlet.CONTEXT"+Servlet名稱。當一個Request對象產生時, 會把這個子上下文對象(WebApplicationContext)保存在Request對象中,key是DispatcherServlet.class.getName() + ".CONTEXT"。 可使用工具類取出上下文對象:RequestContextUtils.getWebApplicationContext(request);--> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- log4j2-begin --> <!-- 注意! 因爲使用3.1版本web.xml log4j2 會自動註冊 若是使用2.5版本xml 須要手動註冊 如下代碼--> <!--<listener>--> <!--<listener-class>org.apache.logging.log4j.web.Log4jServletContextListener</listener-class>--> <!--</listener>--> <!--<filter>--> <!--<filter-name>log4jServletFilter</filter-name>--> <!--<filter-class>org.apache.logging.log4j.web.Log4jServletFilter</filter-class>--> <!--</filter>--> <!--<filter-mapping>--> <!--<filter-name>log4jServletFilter</filter-name>--> <!--<url-pattern>/*</url-pattern>--> <!--<dispatcher>REQUEST</dispatcher>--> <!--<dispatcher>FORWARD</dispatcher>--> <!--<dispatcher>INCLUDE</dispatcher>--> <!--<dispatcher>ERROR</dispatcher>--> <!--</filter-mapping>--> <!-- log4j2-end --> </web-app>
ps:沒什麼說的 使用restfull風格 由於這樣能夠靈活控制以什麼結尾
三、下面是dispatcher的spring配置(這個配置是view層相關的,配置了freemark模板引擎和靜態文件)
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:p="http://www.springframework.org/schema/p" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 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 http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!--配置json適配器--> <mvc:annotation-driven> <mvc:message-converters> <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter4" p:fastJsonConfig-ref="fastJsonConfig"> <property name="supportedMediaTypes"> <list> <value>text/html;charset=UTF-8</value> <value>application/json</value> </list> </property> </bean> </mvc:message-converters> </mvc:annotation-driven> <bean id="fastJsonConfig" class="com.alibaba.fastjson.support.config.FastJsonConfig"> <property name="serializerFeatures"> <list> <value>WriteMapNullValue</value> <value>QuoteFieldNames</value> </list> </property> </bean> <!--註解說明 <context:annotation-config />--> <!-- @Controller 聲明Action組件 @Service 聲明Service組件 @Service("myMovieLister") @Repository 聲明Dao組件 @Component 泛指組件, 當很差歸類時. @RequestMapping("/menu") 請求映射 @Resource 用於注入,( j2ee提供的 ) 默認按名稱裝配,@Resource(name="beanName") @Autowired 用於注入,(spring提供的) 默認按類型裝配 @Transactional( rollbackFor={Exception.class}) 事務管理 @ResponseBody @Scope("prototype") 設定bean的做用域 --> <context:component-scan base-package="com.test.app.controller" /> <mvc:resources mapping="/images/**" location="/images/" cache-period="31556926"/> <mvc:resources mapping="/js/**" location="/js/" cache-period="31556926"/> <mvc:resources mapping="/css/**" location="/css/" cache-period="31556926"/> <!-- freemarker的配置 --> <bean id="freemarkerConfigurer" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <property name="templateLoaderPath" value="/WEB-INF/view/" /> <property name="defaultEncoding" value="UTF-8" /> <property name="freemarkerSettings"> <props> <prop key="template_update_delay">10</prop> <prop key="locale">zh_CN</prop> <prop key="datetime_format">yyyy-MM-dd HH:mm:ss</prop> <prop key="date_format">yyyy-MM-dd</prop> <prop key="number_format">#.##</prop> </props> </property> </bean> <!-- FreeMarker視圖解析 在這裏配置後綴名ftl和視圖解析器。。 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.freemarker.FreeMarkerView" /> <property name="suffix" value=".ftl" /> <property name="contentType" value="text/html;charset=UTF-8" /> <property name="exposeRequestAttributes" value="true" /> <property name="exposeSessionAttributes" value="true" /> <property name="exposeSpringMacroHelpers" value="true" /> </bean> <bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource" p:basename="i18n/messages" /> </beans>
四、下面發下applicationContext-bean.xml的配置
<?xml version="1.0" encoding="UTF-8"?> <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" xmlns:tx="http://www.springframework.org/schema/tx" 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 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <context:component-scan base-package="com.test.app"> <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/> </context:component-scan> <!-- 使用annotation註解方式配置事務 --> <tx:annotation-driven transaction-manager="transactionManager"/> <!-- 使用JDBC事務 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!-- 引入配置文件 --> <context:property-placeholder location="classpath:ini.properties"/> <!--建立jdbc數據源 --> <bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driver}"/> <property name="url" value="${url}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="maxIdle" value="${maxIdle}"/> <property name="minIdle" value="${minIdle}"/> </bean> <!-- 配置SqlSessionFactoryBean --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="configLocation" value="classpath:mybatis.xml"/> <property name="mapperLocations" value="classpath:mapper/*.xml"/> </bean> <!-- 配置mybatis dao註冊,全部dao都繼承sqlMapper annotationClass:當指定了annotationClass的時候,MapperScannerConfigurer將只註冊使用了annotationClass註解標記的接口。 markerInterface:markerInterface是用於指定一個接口的,當指定了markerInterface以後,MapperScannerConfigurer將只註冊繼承自markerInterface的接口。 若是上述兩個屬性都指定了的話,那麼MapperScannerConfigurer將取它們的並集,而不是交集。即便用了annotationClass進行標記或者繼承自markerInterface 的接口都將被註冊爲一個MapperFactoryBean。 除了用於縮小注冊Mapper接口範圍的屬性以外,咱們還能夠指定一些其餘屬性,如: sqlSessionFactory:這個屬性已經廢棄。當咱們使用了多個數據源的時候咱們就須要經過sqlSessionFactory來指定在註冊MapperFactoryBean的時候須要使用的SqlSessionFactory, 由於在沒有指定sqlSessionFactory的時候,會以Autowired的方式自動注入一個。換言之當咱們只使用一個數據源的時候,即只定義了一個SqlSessionFactory的時候咱們就能夠不給 MapperScannerConfigurer指定SqlSessionFactory。 sqlSessionFactoryBeanName:它的功能跟sqlSessionFactory是同樣的,只是它指定的是定義好的SqlSessionFactory對應的bean名稱。 sqlSessionTemplate:這個屬性已經廢棄。它的功能也是至關於sqlSessionFactory的,由於就像前面說的那樣,MapperFactoryBean最終仍是使用的SqlSession的getMapper 方法取的對應的Mapper對象。當定義有多個SqlSessionTemplate的時候才須要指定它。對於一個MapperFactoryBean來講SqlSessionFactory和SqlSessionTemplate只須要其中一個就能夠了, 當二者都指定了的時候,SqlSessionFactory會被忽略。 sqlSessionTemplateBeanName:指定須要使用的sqlSessionTemplate對應的bean名稱。--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <property name="basePackage" value="com.test.app.dao"/> </bean> </beans>
五、ini.properties就不發了
六、generatorConfig.xml配置()
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd" > <generatorConfiguration> <!-- !!!! Driver Class Path !!!! --> <classPathEntry location="E:\.m2\repository\com\microsoft\sqlserver\mssql-jdbc\6.2.0.jre8\mssql-jdbc-6.2.0.jre8.jar"/> <context id="context" targetRuntime="MyBatis3"> <commentGenerator> <property name="suppressAllComments" value="true"/> <property name="suppressDate" value="true"/> </commentGenerator> <!-- !!!! Database Configurations !!!! --> <jdbcConnection driverClass="${datasource.driver}" connectionURL="${datasource.url}" userId="${datasource.username}" password="${datasource.password}"/> <javaTypeResolver> <property name="forceBigDecimals" value="false"/> </javaTypeResolver> <!-- !!!! Model Configurations !!!! --> <javaModelGenerator targetPackage="com.hmc.crm.entity" targetProject="src\main\java"> <property name="enableSubPackages" value="false"/> <property name="trimStrings" value="true"/> </javaModelGenerator> <!-- !!!! Mapper XML Configurations !!!! --> <sqlMapGenerator targetPackage="com.hmc.crm.dao" targetProject="src\main\java\mapper"> <property name="enableSubPackages" value="false"/> </sqlMapGenerator> <!-- !!!! Mapper Interface Configurations !!!! --> <javaClientGenerator targetPackage="com.hmc.crm.dao" targetProject="src\main\java" type="XMLMAPPER"> <property name="enableSubPackages" value="false"/> </javaClientGenerator> <!-- !!!! Table Configurations !!!! --> <table tableName="UserType" enableCountByExample="false" enableDeleteByExample="false" enableSelectByExample="false" enableUpdateByExample="false"/> </context> </generatorConfiguration>
ps:在pom中配置過mybatis的generator插件 會自動讀取 resources下的generatorConfig.xml 只須要雙擊插件便可以下圖:
七、mybatis.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<!-- Globally enables or disables any caches configured in any mapper under this configuration -->
<setting name="cacheEnabled" value="false"/>
<!-- Sets the number of seconds the driver will wait for a response from the database -->
<setting name="defaultStatementTimeout" value="3000"/>
<!-- Enables automatic mapping from classic database column names A_COLUMN to camel case classic Java property names aColumn -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!-- Allows JDBC support for generated keys. A compatible driver is required.
This setting forces generated keys to be used if set to true,
as some drivers deny compatibility but still work -->
<setting name="useGeneratedKeys" value="true"/>
<setting name="logImpl" value="LOG4J2"/>
</settings>
<!-- Continue going here -->
</configuration>
八、log4j2.xml配置
<?xml version="1.0" encoding="UTF-8"?> <Configuration status="off" monitorInterval="1800"> <properties> <property name="LOG_HOME">/logs/sample</property> <property name="FILE_NAME">mylog</property> </properties> <Appenders> <Console name="Console" target="SYSTEM_OUT"> <PatternLayout pattern="%d{HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </Console> <RollingRandomAccessFile name="running-log" fileName="${LOG_HOME}/${FILE_NAME}.log" filePattern="${LOG_HOME}/$${date:yyyy-MM}/${FILE_NAME}-%d{yyyy-MM-dd}-%i.log.gz"> <PatternLayout pattern="%date{yyyy-MM-dd HH:mm:ss.SSS} %level [%thread][%file:%line] - %msg%n"/> <Policies> <TimeBasedTriggeringPolicy/> <SizeBasedTriggeringPolicy size="10 MB"/> </Policies> <DefaultRolloverStrategy max="20"/> </RollingRandomAccessFile> </Appenders> <Loggers> <!--<Logger name="com.test.app" level="trace" additivity="true">--> <!--<AppenderRef ref="running-log"/>--> <!--</Logger>--> <Logger name="com.test.app.dao" level="DEBUG" additivity="true"> <AppenderRef ref="Console"/> </Logger> <Root level="error"> <AppenderRef ref="Console"/> </Root> </Loggers> </Configuration>
ps: 在mybatis.xml中紅色部分配置了日誌實現方式。在log4j2中配置了dao層日誌 爲DEBUG且爲 console 方式 方便調試時查看sql
接下來就是代碼部分:
一、將generator生成的XXXXMapper.java拷貝到dao層下
二、新建HelloService.java和HelloServiceImpl.java 在service層下
public interface HelloService { public List<testModel> getAll(); } @Service public class HelloServiceImpl implements HelloService { @Autowired private XXXMapper dao; public List<testModel> getAllLabels() { return dao.selectAll(); }
}
三、新建HelloController.java 在controller層下
@Controller @RequestMapping("/hello") public class HelloController { @Autowired private HelloService service; @RequestMapping("/index.html") public String index(Model model) { model.addAttribute("title", "hello spring mvc"); model.addAttribute("model","正常顯示"); return "index"; } @RequestMapping("/list.html") public String test(Model model, @RequestParam(defaultValue = "") String key) { List<testModel> ans=service.getAll(); model.addAttribute("all", ans); return "list"; } @RequestMapping("/list") @ResponseBody public List<testModel> list(){ List<testModel> ans=service.getAll(); return ans; }
}
四、在webapp/WEB-INF/view下新建list.ftl
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <table border="1"> <tr> <th>名字</th> <th>年齡</th> </tr> <#list all as label> <tr> <td>${label.name}</td> <td>${label.age}</td> </tr> </#list> </table> </body> </html>
5.運行嘗試
2017-7-16號更新 仍是用spring boot 吧反正都幫你配好了 爲何不用呢 並且還能夠打包成war 手動doge