Spring Boot面试题汇总,含答案

5、点击生 GenerateProject

6、将项目导入 Eclipse。文件 - 导入 - 现有的 Maven 项目

10 Spring Initializr 是创建 Spring Boot Projects 的唯一方法吗?


不是的。

Spring Initiatlizr 让创建 Spring Boot 项目变的很容易,但是,你也可以通过设置一个 maven 项目并添加正确的依赖项来开始一个项目。

在我们的 Spring 课程中,我们使用两种方法来创建项目。

第一种方法是 start.spring.io 。

另外一种方法是在项目的标题为“Basic Web Application”处进行手动设置。

手动设置一个 maven 项目

这里有几个重要的步骤:

1、在 Eclipse 中,使用文件 - 新建 Maven 项目来创建一个新项目

2、添加依赖项。

3、添加 maven 插件。

4、添加 Spring Boot 应用程序类。

到这里,准备工作已经做好!

11 为什么我们需要 spring-boot-maven-plugin?


spring-boot-maven-plugin 提供了一些像 jar 一样打包或者运行应用程序的命令。

1、spring-boot:run 运行你的 SpringBooty 应用程序。

2、spring-boot:repackage 重新打包你的 jar 包或者是 war 包使其可执行

3、spring-boot:start 和 spring-boot:stop 管理 Spring Boot 应用程序的生命周期(也可以说是为了集成测试)。

4、spring-boot:build-info 生成执行器可以使用的构造信息。

12 如何使用 SpringBoot 自动重装我的应用程序?


使用 Spring Boot 开发工具。

把 Spring Boot 开发工具添加进入你的项目是简单的。

把下面的依赖项添加至你的 Spring Boot Project pom.xml 中

重启应用程序,然后就可以了。

同样的,如果你想自动装载页面,有可以看看 FiveReload

http://www.logicbig.com/tutorials/spring-framework/spring-boot/boot-live-reload/.

在我测试的时候,发现了 LiveReload 漏洞,如果你测试时也发现了,请一定要告诉我们。

13 Spring Boot中的监视器是什么?


Spring boot actuator是spring启动框架中的重要功能之一。Spring boot监视器可帮助您访问生产环境中正在运行的应用程序的当前状态。

有几个指标必须在生产环境中进行检查和监控。即使一些外部应用程序可能正在使用这些服务来向相关人员触发警报消息。监视器模块公开了一组可直接作为HTTP URL访问的REST端点来检查状态。

14 什么是YAML?


YAML是一种人类可读的数据序列化语言。它通常用于配置文件。

与属性文件相比,如果我们想要在配置文件中添加复杂的属性,YAML文件就更加结构化,而且更少混淆。可以看出YAML具有分层配置数据。

15 springboot自动配置的原理


在spring程序main方法中 添加@SpringBootApplication或者@EnableAutoConfiguration

会自动去maven中读取每个starter中的spring.factories文件 该文件里配置了所有需要被创建spring容器中的bean

16 springboot读取配置文件的方式


springboot默认读取配置文件为application.properties或者是application.yml

17 springboot集成mybatis的过程


添加mybatis的starter maven依赖

  1. <dependency>

  2. <groupId>org.mybatis.spring.boot</groupId>

  3. <artifactId>mybatis-spring-boot-starter</artifactId>

  4. <version>1.3.2</version>

  5. </dependency>

在mybatis的接口中 添加@Mapper注解

在application.yml配置数据源信息

18 什么是嵌入式服务器?我们为什么要使用嵌入式服务器呢?


思考一下在你的虚拟机上部署应用程序需要些什么。

第一步:安装 Java

第二步:安装 Web 或者是应用程序的服务器(Tomat/Wbesphere/Weblogic 等等)

第三步:部署应用程序 war 包

如果我们想简化这些步骤,应该如何做呢?

让我们来思考如何使服务器成为应用程序的一部分࿱

  • 23
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是常见的 Spring Boot 面试题及其答案: 1. 什么是 Spring BootSpring Boot 是基于 Spring 框架的快速开发脚手架,它提供了常用的配置和依赖管理,使得开发者可以快速构建独立的、生产级别的 Spring 应用程序,而不需要过多的配置。 2. Spring BootSpring 框架的区别是什么? Spring BootSpring 框架的扩展,它提供了自动化配置、快速开发、无需 XML 配置文件等特性,使得开发者能够更快速地构建 Spring 应用程序。 3. Spring Boot 的优点有哪些? Spring Boot 的优点有: - 快速开发:Spring Boot 提供了自动化配置和依赖管理,使得开发者能够更快速地构建应用程序。 - 简化配置:Spring Boot 提供了默认配置,开发者可以根据需要进行修改,而无需进行繁琐的配置。 - 易于部署:Spring Boot 应用程序可以打jar war 进行部署,无需安装应用程序的容器。 - 微服务:Spring Boot 支持微服务开发,可以使用 Spring Cloud 进行服务注册、发现、路由等操作。 - 社区活跃:Spring Boot 拥有庞大的社区,开发者可以从中获取各种资料、解决问题。 4. Spring Boot 中的 starter 是什么? Spring Boot 中的 starter 是一组预定义的依赖,它们含了常用的类库或框架,开发者可以直接引入这些依赖,而无需手动配置相关的依赖。 5. Spring Boot 中的自动配置是什么? Spring Boot 中的自动配置是一种特殊的配置,它会根据应用程序的 classpath 中的 jar 和配置文件,自动配置应用程序的环境。开发者可以通过注解或配置文件进行覆盖或修改。 6. Spring Boot 如何实现热部署? Spring Boot 可以通过添加 devtools 依赖实现热部署。在 pom.xml 中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <optional>true</optional> <scope>runtime</scope> </dependency> ``` 7. Spring Boot 如何实现跨域访问? Spring Boot 可以通过添加 cors 配置实现跨域访问。在配置类中添加以下代码: ```java @Configuration public class CorsConfig { @Bean public WebMvcConfigurer corsConfigurer() { return new WebMvcConfigurer() { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/**") .allowedOrigins("*") .allowedMethods("GET", "POST", "PUT", "DELETE") .allowCredentials(false).maxAge(3600); } }; } } ``` 8. Spring Boot 如何实现缓存? Spring Boot 可以通过添加缓存依赖实现缓存。在 pom.xml 中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId> </dependency> ``` 在配置类中添加以下代码: ```java @Configuration @EnableCaching public class CacheConfig { @Bean public CacheManager cacheManager() { return new ConcurrentMapCacheManager("cacheName"); } } ``` 在需要缓存的方法上添加 @Cacheable 注解即可实现缓存。 9. Spring Boot 如何实现安全认证? Spring Boot 可以通过添加 security 依赖实现安全认证。在 pom.xml 中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> ``` 在配置类中添加以下代码: ```java @Configuration @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests() .antMatchers("/admin/**").hasRole("ADMIN") .antMatchers("/user/**").hasAnyRole("ADMIN", "USER") .antMatchers("/").permitAll() .and() .formLogin() .and() .logout() .logoutUrl("/logout") .logoutSuccessUrl("/login") .invalidateHttpSession(true) .deleteCookies("JSESSIONID"); } @Autowired public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception { auth.inMemoryAuthentication() .withUser("user").password("{noop}password").roles("USER") .and() .withUser("admin").password("{noop}password").roles("ADMIN"); } } ``` 在需要认证的方法上添加 @Secured 注解即可实现安全认证。 以上是常见的 Spring Boot 面试题及其答案,希望对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值