一。对象
POJO(plain old java object):普通的java对象,有别于特殊的java对象(含继承约束等)和EJB。POJO一般只有一系列的属性和相应的get、set方法。
PO(persistant object):持久化对象,有别于POJO,必须对应数据库中的实体。一个PO对应数据库的一条记录。持久化对象的生命周期与数据库密切相关,只能存在于connection之中,连接关闭后,PO就消失了。
PO相对于POJO有诸多不同,比如PO中会有保存数据库entity状态的属性和方法。但是ORM(object-relation mapping)追求的目标是PO和POJO的一致,所以在程序员的日常开发中,都是将POJO作为PO使用,而将POJO转化为PO的功能交给hibernate等框架来实现。
DTO(data transfer object):数据传输对象,以前被称为值对象(VO,value object),作用仅在于在应用程序的各个子系统间传输数据,在表现层展示。与POJO对应一个数据库实体不同,DTO并不对应一个实体,可能仅存储实体的部分属性或加入符合传输需求的其他的属性。
DAO(data access object):数据访问对象。提供访问数据库的抽象接口,或者持久化机制,而不暴露数据库的内部详细信息。DAO提供从程序调用到持久层的匹配。
BO(business object):业务对象。主要是将业务逻辑封装为一个对象,该对象可以包含一个或多个其他对象。如,"Principal"(委托人),有"Name","Age"等属性,同时和"Employee"(雇员)有1对多的关系,这个"Principal"就可以作为一个与业务相关的PO。
二。Bean配置
理解 @Configuration 和 @Bean 注释
创建课程
清单 1. XML 与 bean 定义
<beans> <bean id="course" class="demo.Course"> <property name="module" ref="module"/> </bean> <bean id="module" class="demo.Module"> <property name="assignment" ref="assignment"/> </bean> <bean id="assignment" class="demo.Assignment" /> </beans>
Course
bean,它引用 Module
bean。Module
bean 有一个 Assignment
bean 的引用。您现在要删除这段 XML,编写同等效果的 Java 代码。您将使用基于 Java 的配置定义上面指定的 bean。我们会将 XML 替换为 Java 类,这个 Java 类现在将用作 bean 配置的平台。我们将这个类命名为 AppContext.java
。以下代码展示了 AppContext
类。
清单 2. 包含 bean 定义的 AppContext 配置类
@Configuration public class AppContext { @Bean public Course course() { Course course = new Course(); course.setModule(module()); return course; } @Bean public Module module() { Module module = new Module(); module.setAssignment(assignment()); return module; } @Bean public Assignment assignment() { return new Assignment(); } }
使用 AnnotationConfigApplicationContext 注册配置类
ClassPathXmlApplicationContext
类来加载外部 XML 上下文文件。但在使用基于 Java 的配置时,有一个AnnotationConfigApplicationContext
类。AnnotationConfigApplicationContext
类是 ApplicationContext
接口的一个实现,使您能够注册所注释的配置类。此处的配置类是使用 @Configuration
注释声明的 AppContext
。在注册了所述类之后,@Bean
注释的方法返回的所有 bean 类型也会得到注册。以下代码演示了 AnnotationConfigApplicationContext
清单 3. 使用 AnnotationConfigApplicationContext 注册 AppContext 类
public static void main(String[] args) { ApplicationContext ctx = new AnnotationConfigApplicationContext(AppContext.class); Course course = ctx.getBean(Course.class); course.getName(); }
AppContext
配置类的注册方式是将其传递给 AnnotationConfigApplicationContext
构造函数。此外,您还可以使用所述上下文类的 register
清单 4. 注册 AppContext 类:另外一种方法
public static void main(String[] args) { ApplicationContext ctx = new AnnotationConfigApplicationContext(); ctx.register(AppContext.class) }
清单 5. 使用外部 XML 上下文文件的 web.xml
<web-app> <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/applicationContext.xml</param-value> </context-param> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener> <servlet> <servlet-name>sampleServlet</servlet-name> <servlet-class> org.springframework.web.servlet.DispatcherServlet </servlet-class> </servlet> ... </web-app>
三。Spring boot
1 . springboot简单介绍(http://projects.spring.io/spring-boot/)
现在的web项目几乎都会用到spring框架,而要使用spring难免需要配置大量的xml配置文件,而springboot的出现解 决了这一问题,一个项目甚至不用部署到服务器上直接开跑,真像springboot所说:“just run”。
springboot的很多默认编码方式都是utf-8,真是福利啊。
org.spring 2013年新开发的框架springboot , 它让一个单独项目的创建变得更加的简单,让所有依赖spring的程序可以做到“just run”。springboot提供大量第三方libraries让我们可以非常轻松的开始创建一个spring工程,甚至不需要再去配置一些繁琐的xml配置文件
框架特点:
1:创建独立的spring应用。
2:嵌入Tomcat, Jetty Undertow 而且不需要部署他们。
3:提供的“starters”poms来简化Maven配置
4:尽可能自动配置spring应用。
5:提供生产指标,健壮检查和外部化配置
6:绝对没有代码生成和XML配置要求
2 . 简单实例演示
本文全程使用Springboot当前版本1.2.2(当前,推荐)
一个简单的helloworld 直接开始run main方法就可以了 控制台我也不知道都干了什么,好像是开始部署了,
但是没有关联到我的tomcat。
浏览器就能直接访问了。
3 . 步骤详解
*注意事项:
1.开发第一个springboot程序最好使用maven来搭建,文档全程也是maven构建。
2.springboot因为是一个最新开发的框架,所以只支持java6以上,java7最好,官方推荐java8。
3.需要maven3.2以上版本支持。
4.支持以下servlet容器
也可以将springboot程序部署到所有支持servlet3.0以上的容器
#开发第一个springboot应用 HelloWorld
我这里用的MyEclipse10 java 6 maven 3.2.3 tomcat 7.0.55
新建web project 并添加maven支持。
next之后后面要选择javaee 6.0的library 记住不要选上,因为里面的slf4j会跟springboot自带的产生冲突。
#配置pom.xml
配置pom的时候碰到了很多问题。这里提醒大家一下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>springboot</groupId>
<artifactId>springboot</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>springboot</name>
<description />
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!-- 这里一定要配置上java的版本,如果是1.7版本的可不用配置 -->
<java.version>1.6</java.version>
<!-- 配置你的tomcat版本 -->
<tomcat.version>7.0.55</tomcat.version>
</properties>
<build>
<plugins>
<!--如果是通过parent方式继承spring-boot-starter-parent则不用此插件
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
-->
</plugins>
</build>
<!-- 父依赖 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.2.2.RELEASE</version>
</parent>
<dependencies>
<dependency>
<!-- 导入jar包 -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>springboot</groupId>
<artifactId>springboot</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>springboot</name>
<description />
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<!-- 这里一定要配置上java的版本,如果是1.7版本的可不用配置 -->
<java.version>1.6</java.version>
<!-- 配置你的tomcat版本 -->
<tomcat.version>7.0.55</tomcat.version>
</properties>
<build>
<plugins>
<!--如果是通过parent方式继承spring-boot-starter-parent则不用此插件
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
-->
</plugins>
</build>
<!-- 父依赖 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.2.2.RELEASE</version>
</parent>
<dependencies>
<dependency>
<!-- 导入jar包 -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
</dependencies>
</project>
1. springboot 的logback-classes-1.1.2.jar的包下有一个org.slf4j.impl包 这是springboot真正需要的包而MyEclipse自带的javaEE6.0library里也有一个slf4j包但它不是springboot所需要的,会一直报 NoSuchMethod异常getSingleton()。搞了半天才找到,所以一开始暂时不添加javaEE6.0Library。
2.这里教大家一个快速找到class文件真正所处包的方法。
当无法确定某个类属于哪个包是 可以通过Test.class.getProtectionDomain();来查看
例如:发生noSuchMethod异常时,但是确实有该方法,一般就是重复加载了jar包。
3.官方文档的例子都是用java7运行的。不配置<java.version>1.6</java.version>的话可能 会报版本异常的错误。具体是啥忘了 类似mirro.minor什么51.0的 50表示jdk1.6 51是jdk1.7
4.如果也不配置tomcat版本的话springboot默认会使用8.x版本的tomcat。所以要加一个
<tomcat.version>7.0.55</tomcat.version>来指定你所使用的tomcat版本(视你CATALINA_HOME配 置的所定)。
#编写java代码
package com.i.springboot.controller;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@EnableAutoConfiguration
public class FirstController {
@RequestMapping(value="/")//是springmvc中的注解
String home(){
return "helloworld";
}
public static void main(String[] args) throws Exception {
SpringApplication.run(FirstController.class, args);
}
}
package com.i.springboot.controller;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@EnableAutoConfiguration
public class FirstController {
@RequestMapping(value="/")//是springmvc中的注解
String home(){
return "helloworld";
}
public static void main(String[] args) throws Exception {
SpringApplication.run(FirstController.class, args);
}
}
spring-boot-starter-web所以spring会来创建一 个web应用来配置程序
完成后运行main程序无报错则运行成功。在浏览器输入相应的路径即可获得@RequestMapping返回的数据。
4 . 一个标准的springboot程序结构应该是什么样?
1. spring通常建议我们将main方法所在的类放到一个root包下,@EnableAutoConfiguration(开启自动配置)注解通常都放到main所在类的上面,下面是一个典型的结构布局,供参考
com
+- example
+- myproject
+- Application.java//main方法所在类在最底层
|
+- bean //bean类
| +- Customer.java
| +- CustomerRepository.java
|
+- service //service层
| +- CustomerService.java
|
+- web //controller层
+- CustomerController.java
com
+- example
+- myproject
+- Application.java//main方法所在类在最底层
|
+- bean //bean类
| +- Customer.java
| +- CustomerRepository.java
|
+- service //service层
| +- CustomerService.java
|
+- web //controller层
+- CustomerController.java
从整体看去跟我们平时的布局差不多,就是将main方法放到了最底层。
这样@EnableAutoConfiguration可以从逐层的往下搜索各个加注解的类,例如,你正在编写一个JPA程序(如果你的pom里进行了配置的话),spring会自动去搜索加了@Entity注解的类,并进行调用。
通常我们只需要一个@EnableAutoConfiguration类
ImportResource方式导入xml文件。
下面是一个加载xml文件配置的例子(官方实例)。
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.boot.SpringApplication;
import sample.xml.service.HelloWorldService;
public class SampleSpringXmlApplication implements CommandLineRunner {
@Autowired
private HelloWorldService helloWorldService;
@Override
public void run(String... args) {
System.out.println(this.helloWorldService.getHelloMessage());
}
public static void main(String[] args) throws Exception {
//run的时候加载xml的配置
SpringApplication.run("classpath:/META-INF/application-context.xml", args);
}
}
<!-- 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"
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:annotation-config/>
<context:property-placeholder/>
<bean id="helloService" class="sample.xml.service.HelloWorldService"/>
<bean id="application" class="sample.xml.SampleSpringXmlApplication"/>
</beans>
3. 自动配置对程序没有影响,我们随时可以修改自己的配置来替代自动配置。例如,如果我们添加自己的数据源,那么spring默认的将不再使用。如果你一定要消除某些特定配置可以这样来,如下所示:
import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
import org.springframework.context.annotation.*;
@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}
import org.springframework.boot.autoconfigure.*;
import org.springframework.boot.autoconfigure.jdbc.*;
import org.springframework.context.annotation.*;
@Configuration
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
public class MyConfiguration {
}
@Configuration
,@EnableAutoConfiguration
和
@ComponentScan 并具有他们的默认属性值。
package com.example.myproject;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication //等同于 @Configuration @EnableAutoConfiguration @ComponentScanpublic
class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
package com.example.myproject;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication //等同于 @Configuration @EnableAutoConfiguration @ComponentScanpublic
class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
5. springboot功能全解.
SpringApplication.run(MySpringConfiguration.class, args);
2.自定义打印项(就是控制台输出内容)
在classpath下加入banner.txt 来定义程序启动时要输出的内容,例如我这样
banner的变量:
Variable
Description
${application.version}
MANIFEST.MF中的版本号例如1.0
${application.formatted-version}
格式化后的版本号,就是加了个V,例如V1.0…
${spring-boot.version}
springboot版本号,例如1.2.2.RELEASE.
${spring-boot.formatted-version}
格式化后的Springboot版本号,例如V1.2.2.RELEASE………
3. 自定义SpringApplication
可以自定义一些应用的配置,如下关闭banner输出:
public static void main(String[] args) {
SpringApplication app = new SpringApplication(MySpringConfiguration.class);
app.setShowBanner(false);
app.run(args);
}
public static void main(String[] args) {
SpringApplication app = new SpringApplication(MySpringConfiguration.class);
app.setShowBanner(false);
app.run(args);
}
SpringApplication的一些方法:
SpringApplication的构造器参数往往是一个类.class,而这个类一定是加有@Configuration注解的,另外还可以换成xml的配置路径哦,前面有写出来过,SpringApplication.run("classpath:/META-INF/application-context.xml",args);
4. 流畅的创建API
通过SpringApplicationBuilder构建
new SpringApplicationBuilder()
.showBanner(false)
.sources(Parent.class)
.child(Application.class)
.run(args);
通过SpringApplicationBuilder构建
new SpringApplicationBuilder()
.showBanner(false)
.sources(Parent.class)
.child(Application.class)
.run(args);
5. 程序的事件和监听
除了通常的Spring框架的事件,如ContextRefreshedEvent SpringApplication发送一些额外的应用程序事件。触发一些事件实际上是ApplicationContext之前创建。
除了一些常见的spring时间,像ContextRefreshedEvent SpringApplication会产生一些额外的事件,某些事件甚至会再ApplicationContext创建之间触发。你可以通过很多方式创建监听器,一般最常用的就是如下:
public static void main(String[] args) throws Exception {
SpringApplication app = new SpringApplication(FirstController.class);
app.addListeners(new TestListener());
app.run(args);
}
付一个自定义的listener。
import org.springframework.boot.context.event.ApplicationStartedEvent;
import org.springframework.context.ApplicationListener;
public class TestListener implements ApplicationListener<ApplicationStartedEvent>{
@Override
public void onApplicationEvent(ApplicationStartedEvent event) {
/*do something*/
}
}
public static void main(String[] args) throws Exception {
SpringApplication app = new SpringApplication(FirstController.class);
app.addListeners(new TestListener());
app.run(args);
}
付一个自定义的listener。
import org.springframework.boot.context.event.ApplicationStartedEvent;
import org.springframework.context.ApplicationListener;
public class TestListener implements ApplicationListener<ApplicationStartedEvent>{
@Override
public void onApplicationEvent(ApplicationStartedEvent event) {
/*do something*/
}
}
程序事件运行顺序:
ApplicationStartedEvent is sent at the start of a run, but before any processing except the registration of listeners and initializers.
ApplicationEnvironmentPreparedEvent is sent when the Environment to be used in the context is known, but before the context is created.
ApplicationPreparedEvent is sent just before the refresh is started, but after bean definitions have been loaded.
ApplicationFailedEvent is sent if there is an exception on startup.