idea创建SpringBoot项目及注解配置相关应用小结

 更新时间:2023年11月09日 10:32:12   作者:朱尔斯Jules  
Spring Boot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目,Spring Boot框架,其功能非常简单,便是帮助我们实现自动配置,本文给大家介绍idea创建SpringBoot项目及注解配置相关应用,感兴趣的朋友跟随小编一起看看吧

SpringBoot:

约定大于配置 springboot == ss springboot的版本之间差异较大

一、简言

1、Spring Boot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目。
2、使用Spring Boot很容易创建一个独立运行的项目:脱离自己配置服务器,内部服务器运行
3、使用Spring Boot创建准生产级别的基于Spring框架的项目:企业级发布型项目
4、使用SpringBoot可以不用或者只需要很少的配置文件

二、SpringBoot作用

Spring Boot框架,其功能非常简单,便是帮助我们实现自动配置。我们都知道Spring Boot框架的核心是自动配置。只要有相应的jar包,Spring就会帮助我们实现自动配置,而无需像以前我们使用spring框架一样要做很多配置。当默认配置不能满足我们要求的时候,我们能够用自己的配置来替换这些自动的配置类。此外,上面我们也提到Spring Boot内嵌了web应用容器,除此之外还集成了系统监控等功能,这些都可以帮助我们快速搭建企业级的应用程序并使用。

三、核心功能

1、可以不依赖tomcat等外部容器来独立运行的web项目,springboot的优点是能够以jar包的形式运行。
2、嵌入式的Servlet容器:我们不需要像以前那边先打个war包,然后再运行,在springboot看来这些都是多余的,我们可以选择他内嵌的tomcat、Jetty或者Undertow等容器来直接运行。
3、使pom文件配置更简化:我们只需要在pom文件中添加starter-web依赖即可,无需像以前一样引入很多依赖而造成容易漏掉(自动配置bean)。
4、能够生产环境中直接使用性能指标、健康检查和应用信息等。
5、springboot不需要任何xml文件配置而能实现所有的spring配置

四、创建springBoot项目

1、新建SpringBoot(maven基础下)

创建SpringBoot有两种方式:

  • 一种是从Service URL:start.aliyun.com创建
    • 从中央仓库进行下载,下载速度慢
  • 另一种是从:Service URL:https://start.spring.io/
    • 创建 阿里云镜像仓库

服务地址改变:将网址复制:

因为idea版本不同创建方式显示页面会有不同,但方法都一样,例如2018 IDEA:

2022版 idea 正常创建:

2、next—选版本导jar包

建完maven项目一般仓库还会是在C盘,记得Settings–maven–把库改为自己的(懂得都懂~~)

3、创建后的pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.17.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.Jules</groupId>
    <artifactId>springBoot01</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>springBoot01</name>
    <description>springBoot01</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <spring-boot.version>2.1.17.RELEASE</spring-boot.version>
    </properties>
    <dependencies>    
	    <!-- spring-boot-starter-web会自动帮我们引入开发过程中所需要的web模块jar包,
	    如包含了spring-web和spring-webmvc的依赖,好处就是我们不需要逐个的去导入,
	    只需要导入一个就可以,这样可以避免遗漏或者版本问题。 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring-boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
<!-- 自己的插件配置,我自己的插件生成的,省略了,不重要 -->
    <build>
        <plugins>
            <plugin>
                …………
            </plugin>
            …………
        </plugins>
    </build>
</project>

这段最重要:

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.17.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

此项目其他会使用的jar包

<!--mysql驱动-->
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.44</version>
    </dependency>
<!--数据库连接-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jdbc</artifactId>
    </dependency>
<!--实体类注解包-->      
    <dependency>
         <groupId>org.projectlombok</groupId>
         <artifactId>lombok</artifactId>
     </dependency>
<!--mybatis的包支持sqpeingboot-->
     <dependency>
         <groupId>org.mybatis.spring.boot</groupId>
         <artifactId>mybatis-spring-boot-starter</artifactId>
         <version>2.1.3</version>
     </dependency>

4、SpringBoot启动类

在src—main—java中会生成下面的核心启动类,直接运行就会开启服务器

@SpringBootApplication /*核心注解*/
public class SpringBoot01Application {
    public static void main(String[] args) {
        SpringApplication.run(SpringBoot01Application.class, args);
    }
}

==============若是不想用他的服务器可以配置自己的,后面(九)=============

​​​​​

【核心注解@SpringBootApplication】

  • @SpringBootApplication注解是多个注解的合体,其中最重要的=======
  • @SpringBootConfiguration是spring注解(启动tomcat时加载当前类),
  • @EnableAutoConfiguration(实现自动装配),
  • @ComponentScan(扫描service,controller层)
  • @SpringBootConfiguration 继承至@Configuration,其实两种功能一致,都是标注该类为配置类,
  • 读取启动类
  • @EnableAutoConfiguration 这个注解是SpirngBoot自动配置的核心所在,通过此注解,能所有符合自
  • 动配置条件的bean的定义加载到spring容器中。
  • @ComponentScan 该注解会扫描当前包及子包下面被纳入sping容器管理的类,相当于 <context:component-scan base-package=“com.hz.service”/>。

六、测试项目

【先配置好第七步的application.yml中的配置】

1.项目构建:

实体类省略……………后端代码:

//dao层接口、service层接口
//@Repository  //dao接口注解,如果不要在service的实现层会有一个报红,但不会影响项目执行
public interface ProviderMapper {
    /**
     *
     * @param proName
     * @param pyl  偏移量
     * @param limit  页面容量
     * @return
     */
    public List<Provider> providerInfoList(
            @Param("proName") String proName,
            @Param("pyl") Integer pyl,
            @Param("limit") Integer limit
    );
}
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.jules.springboot01.mapper.ProviderMapper">
    <select id="providerInfoList" resultType="com.jules.springboot01.pojo.Provider">
        select * from smbms_provider
        <where>
            <if test="proName != null and proName != ''">
                and proName like concat('%',#{proName},'%')
            </if>
        </where>
        order by id desc limit #{pyl},#{limit}
    </select>
</mapper>
//service层实现
@Service
public class ProviderServiceImpl implements ProviderService {
    @Autowired
    private ProviderMapper providerMapper;  //前面说的报红就是这里,不影响
    public List<Provider> providerInfoList(String proName,Integer page, Integer limit) {
        //计算偏移量
        int pyl = (page-1)*limit;
        return providerMapper.providerInfoList(proName,pyl,limit);
    }
}
//controller层
@Controller
@ResponseBody
@RequestMapping("/xxx")
public class ProviderController {
    @Autowired
    private ProviderService providerService;
    @RequestMapping(value = "/providerInfoList",method = RequestMethod.GET)
    @ResponseBody
    public List<Provider> providerInfoList(String proName,Integer page, Integer limit){
        System.out.println("proName=="+proName);
        List<Provider> providers = providerService.providerInfoList(proName,1,10);
        return providers;
    }
}

2.数据源注入dao层—@MapperScan

【到此speingBoot构建好了,项目创建完成,虽然数据库连接与创建数据源已完成,但是数据源注入dao层还没有完成】

@MapperScan

  • 作用:指定要变成实现类的接口所在的包,然后包下面的所有接口在编译之后都会生成相应的实现类
  • 添加位置:是在Springboot启动类上面添加
@SpringBootApplication
@MapperScan("com.jules.springboot01.mapper")
public class SpringBoot01Application {
    public static void main(String[] args) {
        SpringApplication.run(SpringBoot01Application.class, args);
    }
}

【启动,运行路径:http://localhost:8080/xxx/providerInfoLis拿到数据库的数据】

七、关于application.properties文件

application.properties格式文件

#配置相关配置,格式如下
#项目名
spring.application.name: springBoot01
#端口号
service.port: 8080

application.properties可以将后缀名改为.yml文件,application.yml格式如下(冒号后面空格一下;项目用此格式):

#数据库连接(导jar包)
spring:
  datasource:
    url: jdbc:mysql://localhost:3306/数据库名称?useUnicode=true&characterEncoding=utf8&useSSL=false
    driver-class-name: com.mysql.jdbc.Driver
    username: xxxx
    password: xxxx
# 端口号
server:
  port: 8080
namevo: 朱尔斯
# mybatis相关配置
mybatis:
  mapper-locations: classpath:mapper/*.xml  #扫描mapper(dao层)
  type-aliases-package: com.jules.springboot01.pojo    #别名
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl #SQL控制台打印

【有关静态资源配置:】

不配置静态资源,直接访问index.html,报错:

配置静态资源就可以正常进入index.html;也可以本地磁盘

spring: 
	resources: 
		static-locations: classpath:/templates,classpath:/static/,file:D://

八、注解

@Configuration

标注一个类为配置类:可以自己创建配置文件类,加上@Configuration则表示是配置文件,项目启动会先加载此类。

@Bean

用@Bean标注方法等价于XML中配置的bean

@ConfigurationProperties + @Value

读取properties或yml文件+读取里面的值

示例:

@Configuration //容器启动时加载
//@ConfigurationProperties("application.yml")
public class AppConfig {
	@Value("${namevo}")
	private String namevo;
	//创建bean实例 别名为stu
	@Bean(name = "stu")
	public Student getStudent(){
		Student stu = new Student();
		stu.setStudentName("Jules");
		return stu;
	}
}

@ComponentScan

  • 此注解已经存在@SpringBootApplication中,自动扫描当前包以及子包service,controller层
  • 如果扫描非当前包,则需要在添加@ComponentScan()去扫描@ComponentScan("com.jules.springBoot")多包逗号隔开

或者使用@SpringBootApplication注解的scanBasePackages属性进行配置@SpringBootApplication(scanBasePackages ={"com.jules.service","com.jules.controller"})多包使用数组形式

@EnableTransactionManagement

  • 开启事务注解:在总局上开启则在启动类上使用@EnableTransactionManagement
  • 具体使用事务:用@Transactional注解,例如service层,谁用则在方法上@Transactional

九、配置外部容器:

1.去掉pom.xml中默认加载的tomcat,并添加servlet-api

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-web</artifactId>
	<!--移除tomcat-->
	<exclusions>
		<exclusion>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-tomcat</artifactId>
		</exclusion>
	</exclusions>
</dependency>
<dependency>
	<groupId>javax.servlet</groupId>
	<artifactId>javax.servlet-api</artifactId>
	<version>4.0.1</version>
	<scope>provided</scope>
</dependency>

2.覆盖启动类

//使启动类继承 SpringBootServletInitializer 类,并覆盖 configure 方法
@SpringBootApplication
public class SpringbootCSApplication extends SpringBootServletInitializer {
	//覆盖configure方法
	protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
		return builder.sources(SpringbootCS.class);
	}
	public static void main(String[] args) {
		SpringApplication.run(SpringbootCS.class, args);
	}
}

3.加入自己的服务器

跟以前的加入与启动服务器是一样的

十、SpringBoot中application.xxx配置文件的加载顺序

问:在正常项目下有一个application.yml文件和application.properties文件,先加载哪个文件?

答:先加载后缀为.properties的,如果.yml中的有相同的配置,则不会在加载.yml配置。按优先级排序,位置高的将覆盖位置低的(properties位置高)。

比如:

# application.properties文件
namevo: 朱尔斯
# application.yml文件
namevo: Jules

执行输出的会是:“朱尔斯”

如果在不同的目录中存在多个配置文件,它的读取顺序是:

1、项目根目录下的config文件中的:

  • config/application.properties
  • config/application.yml

2、项目根目录下的:

  • application.properties
  • application.yml

3、项目resources目录下config目录中的:

  • resources/config/application.properties
  • resources/config/application.yml

4、项目的resources目录下(项目创建自动生成的):

  • resources/application.properties(项目的resources目录下)
  • resources/application.yml

到此这篇关于idea创建SpringBoot项目及注解配置相关应用的文章就介绍到这了,更多相关idea创建SpringBoot项目内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring中的@Scheduled定时任务注解详解

    Spring中的@Scheduled定时任务注解详解

    这篇文章主要介绍了Spring中的@Scheduled定时任务注解详解,要使用@Scheduled注解,首先需要在启动类添加@EnableScheduling,启用Spring的计划任务执行功能,这样可以在容器中的任何Spring管理的bean上检测@Scheduled注解,执行计划任务,需要的朋友可以参考下
    2023-09-09
  • 详解Java中native关键字

    详解Java中native关键字

    这篇文章主要为大家详细介绍了Java中native关键字,什么是Native Method
    2016-02-02
  • Java负载均衡服务器实现上传文件同步

    Java负载均衡服务器实现上传文件同步

    这篇文章主要介绍了Java负载均衡服务器实现上传文件同步,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 货拉拉大数据对BitMap的探索实践详解

    货拉拉大数据对BitMap的探索实践详解

    这篇文章主要为大家介绍了货拉拉大数据对BitMap的探索实践详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • Spinrg WebFlux中Cookie的读写的示例

    Spinrg WebFlux中Cookie的读写的示例

    这篇文章主要介绍了Spinrg WebFlux中Cookie的读写的示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-01-01
  • JMeter配置元件详解

    JMeter配置元件详解

    JMeter提供了丰富的配置元件,常用的包括参数化配置元件、HTTP请求默认值、HTTP信息头管理器、计数器等,本文就详细的介绍一下这些元件的使用,感兴趣的可以了解一下
    2021-12-12
  • mybatis判断int是否为空的时候,需要注意的3点

    mybatis判断int是否为空的时候,需要注意的3点

    这篇文章主要介绍了mybatis判断int是否为空的时候,需要注意的3点,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Java Jwt库的简介及使用详解

    Java Jwt库的简介及使用详解

    JWT 是开放的行业标准RFC7591,用来实现端到端安全验证,就是通过一些算法对加密字符串和JSON对象之间进行加解密,下面通过本文给大家介绍Java Jwt库的简介及使用,感兴趣的朋友一起看看吧
    2021-11-11
  • Java Stax解析XML示例

    Java Stax解析XML示例

    这篇文章主要介绍了Java Stax解析XML示例,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-09-09
  • Java微信公众平台之消息管理

    Java微信公众平台之消息管理

    这篇文章主要为大家详细介绍了Java微信公众平台之消息管理的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05

最新评论