本文共 11552 字,大约阅读时间需要 38 分钟。
springboot知识点复习梳理
导读:springboot相比于ssm来说,就是将其中复杂的xml文件配置转化成了java配置。
一、我们先来一个简单的案例演示,通过Java配置的方式进行配置Spring,并且实现了Spring IOC功能。 1.首先 是pom文件的依赖导入4.0.0 cn.itcast.springboot itcast-springboot 1.0.0-SNAPSHOT war
2.创建一个pojo对象user package cn.itcast.springboot.javaconfig; public class User { private String username; private String password; private Integer age; . . . } 3.编写UserDao 模拟实现一个查询数据库方法 package cn.itcast.springboot.javaconfig;org.springframework spring-webmvc 4.3.7.RELEASE com.jolbox bonecp-spring 0.8.0.RELEASE ${project.artifactId} org.apache.maven.plugins maven-resources-plugin UTF-8 org.apache.maven.plugins maven-compiler-plugin org.apache.tomcat.maven tomcat7-maven-plugin 2.2
import java.util.ArrayList;
import java.util.List;public class UserDAO {
public ListqueryUserList(){ List result = new ArrayList (); // 模拟数据库的查询 for (int i = 0; i < 10; i++) { User user = new User(); user.setUsername("username_" + i); user.setPassword("password_" + i); user.setAge(i + 1); result.add(user); } return result;}
}
4.编写Service用于实现User数据操作业务逻辑
package cn.itcast.springboot.javaconfig; import java.util.List; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service //service注解,为后面的扫描做准备 public class UserService { @Autowired // 注入Spring容器中的bean对象 private UserDAO userDAO;public ListqueryUserList() { // 调用userDAO中的方法进行查询 return this.userDAO.queryUserList();}
}
5.编写SpringConfig 用于实例化Spring容器 @Configuration //通过该注解来表明该类是一个Spring的配置,相当于一个xml文件 @ComponentScan(basePackages = “cn.itcast.springboot.javaconfig”) //配置扫描包,用于扫描service public class SpringConfig {@Bean // 通过该注解来表明是一个Bean对象,相当于xml中的public UserDAO getUserDAO(){ return new UserDAO(); // 直接new对象做演示}
}
6.编写测试方法 用于启动Spring容器 (1)本步重点: AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class); 通过此上下文的类来读取刚才实例化spring容器的类public class Main { public static void main(String[] args) { // 通过Java配置来实例化Spring容器 AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class); // 在Spring容器中获取Bean对象 UserService userService = context.getBean(UserService.class); // 调用对象中的方法 Listlist = userService.queryUserList(); for (User user : list) { System.out.println(user.getUsername() + ", " + user.getPassword() + ", " + user.getPassword()); } // 销毁该容器 context.destroy(); }}
二、小案例实战,用springboot的知识来取代ssm中的xml配置文件
1.创建一个类HelloApplication (1)此类有三个注解:Controller SpringBootApplication Configuration 第一个注解表明此类是个控制层的类,可以用来处理逻辑; 第二个注解是核心,所有的springboot的启动类都需要这个注解; 第三个注解又表明此类是个xml文件。@Controller
@SpringBootApplication @Configurationpublic class HelloApplication {
(2)
1: @RequestMapping(value=“hello”) 访问时的路径映射 2:@ResponseBody 将controller的方法返回的对象通过适当的转换器转换为指定的格式之后,写入到response对象的body区,通常用来返回JSON数据或者是XML数据@RequestMapping(value="hello")@ResponseBodypublic String hello(){ return "hello world!传智播客";}
(3)@Bean
这一部分的引用Bean注解,相当于xml文件里面的一个对象,来知名当前数据的编码方式@Beanpublic StringHttpMessageConverter stringHttpMessageConverter(){ StringHttpMessageConverter converter = new StringHttpMessageConverter(Charset.forName("ISO-8859-1")); return converter;
}
(4)main方法 在每一个springboot的启动类里面一定要有一个main方法,用来启动想要启动的类 SpringApplication是前面注解的方法,调用当中的run方法,来启动配置java类。public static void main(String[] args) { SpringApplication.run(HelloApplication.class, args);}
}
2.自定义拦截器 创建一个类来继承WebMvcConfigurerAdapter@Configuration //申明这是一个配置public class MySrpingMVCConfig extends WebMvcConfigurerAdapter{ // 自定义拦截器 @Override public void addInterceptors(InterceptorRegistry registry) { HandlerInterceptor handlerInterceptor = new HandlerInterceptor() { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("自定义拦截器............"); return true; }
@Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { } }; registry.addInterceptor(handlerInterceptor).addPathPatterns("/**");}// 自定义消息转化器的第二种方法@Overridepublic void configureMessageConverters(List> converters) { StringHttpMessageConverter converter = new StringHttpMessageConverter(Charset.forName("UTF-8")); converters.add(converter);}
}
三、springboot实现改造购物车。
1.导入依赖 (1)最为重要的org.springframework.boot spring-boot-starter-parent 1.5.2.RELEASE
在springboot的依赖中,父依赖必须要为springboot的父依赖,不能用我们自己定义的父依赖,里面包含了大量的配置。
(2)重要的org.springframework.boot spring-boot-starter-web
这是编写web的时候要导入的springboot依赖。
2.创建java类代替xml文件
1.替换applicationContext-dao.xml (1)创建TaotaoApplication类完成对数据库连接访问 解释:1.@PropertySource注解是用来读取properties文件的, ignoreResourceNotFound = true 如果properties文件没找到依旧执行,不会报错。 2.@ComponentScan主要就是定义扫描的路径从中找出标识了需要装配的类自动装配到spring的bean容器中,像@Controller,@Service,@Repository,@Component等注解都在扫描范围内 3. @Value(" j d b c . u r l " ) p r i v a t e S t r i n g j d b c U r l ; 定 义 一 个 s t r i n g 类 型 的 变 量 j d b c U r l , 将 其 值 赋 值 为 {jdbc.url}") private String jdbcUrl; 定义一个string类型的变量jdbcUrl,将其值赋值为 jdbc.url")privateStringjdbcUrl;定义一个string类型的变量jdbcUrl,将其值赋值为{jdbc.url},因为前面的扫描已经读取了jdbc.properties里面的内容@Configuration@PropertySource(value={ "classpath:jdbc.properties", "classpath:env.properties","classpath:httpclient.properties"}, ignoreResourceNotFound = true)@ComponentScan(basePackages="com.taotao")public class TaotaoApplication { @Value("${jdbc.url}") private String jdbcUrl; @Value("${jdbc.driverClassName}") private String jdbcDriverClassName; @Value("${jdbc.username}") private String jdbcUsername; @Value("${jdbc.password}") private String jdbcPassword; @Bean(destroyMethod="close") public DataSource dataSource() { BoneCPDataSource boneCPDataSource = new BoneCPDataSource(); boneCPDataSource.setDriverClass(jdbcDriverClassName); // 相应驱动的jdbcUrl boneCPDataSource.setJdbcUrl(jdbcUrl); // 数据库的用户名 boneCPDataSource.setUsername(jdbcUsername); // 数据库的密码 boneCPDataSource.setPassword(jdbcUsername); // 检查数据库连接池中空闲连接的间隔时间,单位是分,默认值:240,如果要取消则设置为0 boneCPDataSource.setIdleConnectionTestPeriodInMinutes(60); // 连接池中未使用的链接最大存活时间,单位是分,默认值:60,如果要永远存活设置为0 boneCPDataSource.setIdleMaxAgeInMinutes(30); // 每个分区最大的连接数 boneCPDataSource.setMaxConnectionsPerPartition(100); // 每个分区最小的连接数 boneCPDataSource.setMinConnectionsPerPartition(5); return boneCPDataSource; }
这是以前xml文件的连接池
2.创建一个类MyBatisConfig来代替mybatisxml配置
解释: @ConditionalOnMissingBean 这个注解的意思就是 如果当前运行中没有这个@Bean类 那么就创建,如果有,则无所谓@Configurationpublic class MyBatisConfig { @Bean @ConditionalOnMissingBean public SqlSessionFactoryBean sqlSessionFactoryBean(DataSource dataSource) { SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean(); // 设置数据源 sqlSessionFactoryBean.setDataSource(dataSource); // 设置mybatis的主配置文件 ResourcePatternResolver resolver = new PathMatchingResourcePatternResolver(); Resource mybatisConfigXml = resolver.getResource("classpath:mybatis/mybatis-config.xml"); sqlSessionFactoryBean.setConfigLocation(mybatisConfigXml); // 设置别名包 sqlSessionFactoryBean.setTypeAliasesPackage("com.taotao.cart.pojo"); return sqlSessionFactoryBean; }}
这是以前xml文件的配置
3.创建一个类MapperScannerConfig代替以前xml配置中的mapper扫描
@Configuration@AutoConfigureAfter(MyBatisConfig.class) //保证在MyBatisConfig实例化之后再实例化该类public class MapperScannerConfig { // mapper接口的扫描器 @Bean public MapperScannerConfigurer mapperScannerConfigurer() { MapperScannerConfigurer mapperScannerConfigurer = new MapperScannerConfigurer(); mapperScannerConfigurer.setBasePackage("com.taotao.cart.mapper"); return mapperScannerConfigurer; }}
这是以前xml文件的配置
4.全局配置文件
创建一个文件application.propertirs (1)server.port:8086 //指定当前运行的端口号(2)server.servlet-path:/ 修改进入DispatcherServlet的规则为:/
(3)如果进入SpringMVC的规则为/时,Spring Boot的默认静态资源的路径为:
spring.resources.static-locations=classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/(4)进入规则为*.xxx 或者 不指定静态文件路径时
将静态资源放置到webapp下的static目录中即可通过地址访问5.Spring Boot的自动配置的原理
Spring Boot在进行SpringApplication对象实例化时会加载META-INF/spring.factories文件,将该配置文件中的配置载入到Spring容器。6.设置事务管理
在Spring Boot中推荐使用@Transactional注解来申明事务。首先需要导入依赖:
org.springframework.boot spring-boot-starter-jdbc当引入jdbc依赖之后,Spring Boot会自动默认分别注入DataSourceTransactionManager或JpaTransactionManager,所以我们不需要任何额外配置就可以用@Transactional注解进行事务的使用。
在Service中添加@Transactional注解:
7.设置SpringMVC的配置6.4.1. 启动错误1
关键错误(丢失了web容器的工厂,也就是说我们并没有把它作为一个web应用来启动):
org.springframework.context.ApplicationContextException: Unable to start embedded container; nested exception is org.springframework.context.ApplicationContextException: Unable to start EmbeddedWebApplicationContext due to missing EmbeddedServletContainerFactory bean.解决:
让Spring Boot来自动选择并且完成web的相关加载工作。
6.4.2. Slf4j日志警告 提示我们当前的项目中slf4j引入了2个,导致了jar冲突。解决:
1、 删除自己引入到slf4j的依赖2、 将taotao-common中传递的依赖排除掉
6.4.3. 解决jsp访问404的问题
由于Spring boot使用的内嵌的tomcat,而内嵌的tamcat是不支持jsp页面的,所有需要导入额外的包才能解决。 org.apache.tomcat.embed tomcat-embed-jasper provided6.4.4. 拦截器中的UserService空指针异常
分析:由于添加拦截器时,直接对UserLoginHandlerInterceptor进行new操作,导致UserService无法注入,所以有空指针异常。解决:
打包成功:
7.5. 部署到tomcat 解压apache-tomcat-7.0.57.tar.gz,将war包解压到webapps下的ROOT目录中,启动:转载地址:http://sfkti.baihongyu.com/