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
|