build.gradle:
apply plugin: 'groovy' apply plugin: 'war' apply plugin: 'jetty' sourceCompatibility = 1.8 targetCompatibility = 1.8 repositories { mavenLocal() mavenCentral() } def springVersion = '4.1.7.RELEASE' def groovyVersion = '2.4.5' def aspectjVersion = '1.8.7' def currentEnvironment = project.hasProperty("environment")?environment:"development" dependencies { compile "org.springframework:spring-webmvc:${springVersion}" compile "org.codehaus.groovy:groovy:${groovyVersion}" compile 'log4j:log4j:1.2.17' } jettyRun{ contextPath = "jmailer" httpPort = 8080 } jettyRunWar{ contextPath = "jmailer" httpPort = 8080 } println "Setting environment to: ${currentEnvironment}" task settingLog4jProperties(type:Copy){ from "${System.getProperty('user.home')}/.jmailer/log4j-${currentEnvironment}.properties" into "src/main/resources/" rename { String fileName -> fileName.replace("-${currentEnvironment}", '') } } processResources.dependsOn "settingLog4jProperties"
Spring Boot控制器
@Controller class EmailerController { @Autowired EmailerService emailerService Log log = LogFactory.getLog(this.class) @RequestMapping(value = '/', method = GET) String index(Map<String, Object> model) { log.debug 'Calling index' model.put('title', emailerService.getTitle('World!')) model.put('msg', emailerService.getDescription()) return 'index' } }
服务:
@Service class EmailerService { Log log = LogFactory.getLog(this.class) String getTitle(String name) { log.debug "GETTING title with name : ${name}" "Hello ${name}" } String getDescription() { log.debug "GETTING description" "Jmailer is a service for delivering emails" } }
视图:
JSP + JSTL + bootstrap。一个简单的JSP页面,用于显示模型,并包含静态资源,如css和js。
文件:/WEB-INF/views/jsp/index.jsp
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> <!DOCTYPE html> <html lang="en"> <head> <title>Jmailer</title> <spring:url value="/resources/core/css/jmailer.css" var="coreCss" /> <spring:url value="/resources/core/css/bootstrap.min.css" var="bootstrapCss" /> <link href="${bootstrapCss}" rel="stylesheet" /> <link href="${coreCss}" rel="stylesheet" /> </head> <nav class="navbar navbar-inverse navbar-fixed-top"> <div class="container"> <div class="navbar-header"> <a class="navbar-brand" href="#">Email deliver service</a> </div> </div> </nav> <div class="jumbotron"> <div class="container"> <h1>${title}</h1> <p> <c:if test="${not empty msg}"> About: ${msg} </c:if> </p> <p> <a class="btn btn-primary btn-lg" href="#" role="button">Learn more</a> </p> </div> </div> <div class="container"> <div class="row"> <div class="col-md-4"> <h2>Heading</h2> <p>Text</p> <p> <a class="btn btn-default" href="#" role="button">Action</a> </p> </div> </div> <hr> <footer> <p>© josdem 2015</p> </footer> </div> <spring:url value="/resources/core/css/hello.js" var="coreJs" /> <spring:url value="/resources/core/css/bootstrap.min.js" var="bootstrapJs" /> </body> </html>
Spring XML配置
文件:/WEB-INF/dispatcher-servlet.xml
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd "> <context:component-scan base-package="com.jos.dem.jmailer" /> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> <property name="prefix" value="/WEB-INF/views/jsp/" /> <property name="suffix" value=".jsp" /> </bean> <mvc:resources mapping="/resources/**" location="/resources/" /> <mvc:annotation-driven /> </beans>
文件:/WEB-INF/web.xml
<web-app 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-app_3_0.xsd" version="3.0"> <display-name>Jmailer</display-name> <description>Emailer deliver service</description> <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
根目录下创建一个名为.jmailer的文件夹并添加此log4j文件
文件:log4j-development.properties
# # The logging properties used for eclipse testing, We want to see INFO output on the console. # log4j.rootLogger=out log4j.logger.com.jos.dem=DEBUG,out log4j.logger.org.springframework=INFO,out log4j.logger.org.springframework.transaction=DEBUG log4j.logger.org.springframework.jmx=ERROR,out log4j.logger.org.springframework.aop=DEBUG log4j.logger.org.hibernate=ERROR,out log4j.logger.org.apache.commons.beanutils=ERROR,out log4j.logger.org.displaytag=ERROR,out log4j.logger.net.sf=ERROR,out #Ensure the logs don't add to each other log4j.additivity.com.tim.one=false log4j.additivity.org.springframework=false log4j.additivity.org.springframework.jmx=false log4j.additivity.org.hibernate=false log4j.additivity.org.apache.commons.beanutils=false log4j.additivity.org.displaytag=false log4j.additivity.net.sf=false log4j.appender.out=org.apache.log4j.ConsoleAppender log4j.appender.out.layout=org.apache.log4j.PatternLayout log4j.appender.out.layout.ConversionPattern=%d %5p [%t] (%F:%L) - %m%n
主目录并键入:
gradle jettyRun
进入浏览器: http:// localhost:8080 / jmailer /
源码下载:
git clone https://github.com/josdem/jmailer-bootstrap.git git fetch git checkout setup