• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

wvuong/spring-mvc-bootstrap-angularjs-starter: Jumpstart your Maven-based Spring ...

原作者: [db:作者] 来自: 网络 收藏 邀请

开源软件名称(OpenSource Name):

wvuong/spring-mvc-bootstrap-angularjs-starter

开源软件地址(OpenSource Url):

https://github.com/wvuong/spring-mvc-bootstrap-angularjs-starter

开源编程语言(OpenSource Language):

JavaScript 77.4%

开源软件介绍(OpenSource Introduction):

spring-mvc-bootstrap-angularjs-starter

The purpose of this is to serve as a project base that has the following things built in:

  • Maven project structure and configuration
  • Spring MVC and default mappings
  • Bootstrap resources and starter page
  • AngularJS resources and starter page
  • Application defaults like logging, exception handling, and login.

So clone it and get started.

Main components

How it is configured

Maven is configured to compile for JDK7 so make sure that you have your JAVA_HOME configured correctly (you can check this also by running mvn --version).

Let's get this thing running:

mvn jetty:run

The root of all configuration starts in the src/main/webapp/WEB-INF/web.xml file. The web.xml uses the ContextLoaderListener to initialize the Spring application context via @Configuration annotation scanning (the contextClass and contextConfigLocation context-params). In this case, the web.xml's contextConfigLocation context-param directs the ContextLoaderListener to load the main/parent application context in the annotated class com.willvuong.bootstrapper.config.AppConfiguration.

<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>com.willvuong.bootstrapper.config.AppConfiguration</param-value>
</context-param>

The AppConfiguration class should use @Import and/or @ComponentScan annotations to import other @Configuration classes or annotated @Component-ish classes.

The Spring MVC context is configured via the DispatcherServlet's contextConfigLocation init-param value:

<servlet>
		<servlet-name>appServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextClass</param-name>
            <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value>
        </init-param>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>com.willvuong.bootstrapper.mvcconfig.MvcConfiguration</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
		<async-supported>true</async-supported>
</servlet>

The MvcConfiguration class configures the Spring MVC framework with some "classic" defaults and already has a @ComponentScan annotation for mapping annotated @Controller classes in the com.willvuong.bootstrapper.controllers package.

Let's talk about the "classic" defaults:

  • The DispatcherServlet is configured to map to all requests within the servlet context via /*.
  • MvcConfiguration is configured to route all /resources/** requests to static resources located in src/main/webapp/resources.
  • All unmatched requests are finally routed to the default servlet handler.

If you paid attention to the console output during mvn jetty:run, you might have seen a few lines that begin with "autoconfiguring blah blah...". These log statements originate from the class com.willvuong.bootstrapper.mvcconfig.ServletContextAutoConfigure which does some additional configuration of the servlet context.

  • A utility filter com.willvuong.bootstrapper.filter.RequestMDCServletFilter is added to the servlet context. Its main purpose is to set details from the current HttpServletRequest (request URL, request URI, and generate a unique logging ID for the scope of the current request) into the SLF4J MDC.
  • Configure SiteMesh to decorate all responses except for static resources in /resources/**. SiteMesh is configured by src/main/webapp/WEB-INF/decorators.xml.
  • Configure Metrics instrumentation and reporting via Metrics servlets.

Another thing to pay attention to is the Logback configuration (via src/main/resources/logback.xml).

  • Logback is started in debug mode and will refresh its configuration every 30 seconds.
  • It will log to the console in color for readability. (If you are running in a terminal emulator without color, you can disable colors like mvn jetty:run -Dnocolor=true.)
  • Log messages are very detailed and include the current request URI and request ID. This helps to map request handlers to log messages.

Open up a web browser and navigate to localhost:8080 and click on the currently running servlet context (if you didn't change the pom.xml artifactId yet, it will be "spring-mvc-bootstrap-angularjs-starter").

  • The web page you should see is mapped by controller com.willvuong.bootstrapper.controllers.HomeController which all it does is forward to /WEB-INF/views/angular-index.jsp.
  • JSP /WEB-INF/views/angular-index.jsp is located at src/main/webapp/WEB-INF/views/angular-index.jsp. It references JavaScript and Angular resources in /resources/ (src/main/webapp/resources).
  • The response is decorated by SiteMesh by src/main/webapp/WEB-INF/decorators/default.jsp. This JSP decorator wraps angular-index.jsp in Bootstrap CSS styling in /resources/ (src/main/webapp/resources).

Metrics reporting is exposed via:

  • Application metrics: {contextpath}/diagnostics/metrics
  • JVM metrics: {contextpath}/diagnostics/jvm
  • Thread dump: {contextpath}/diagnostics/threads
  • Health checks: {contextpath}/diagnostics/health
  • Ping: {contextpath}/diagnostics/ping

To kill the Jetty server, use Control-c.

Hot development mode (aka class reloading)

You could just reload the servlet context in the Jetty command line after every recompile by hitting enter (at least until you run out of heap space!) but that really sucks most times. (Also a reminder that you don't have to reload the servlet context for JSP or static resource changes as they are LIVE since mvn jetty:run is serving directly out of src/main/webapp.)

If you have JRebel, you should already be good to go via IDE plugin or attaching the JRebel agent to the JVM.

Otherwise, the Spring Loaded project can serve as a poor man's JRebel in a pinch. The Spring Loaded jar is located in the tools directory and all of the configuration is in the pom.xml (jetty-maven-plugin and the debug profile).

To start your app in Jetty with Spring Loaded: mvn jetty:run-forked

To start your app in Jetty with Spring Loaded and JDWP on port 5005: mvn jetty:run-forked -P debug

Packaging for deployment

TODO




鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap