Spring Boot框架

122 篇文章 2 订阅
117 篇文章 0 订阅

目录

一、Spring Boot

1、Spring Boot优点

2、创建Spring Boot

3、Spring Boot配置文件

(1)配置文件的作用

(2)properties文件格式

(3)yml文件的格式

(4)properties vs yml

二、Spring Boot日志框架

1、java常见的日志框架

2、日志级别

3、日志打印


一、Spring Boot

Spring Boot也是Spring官方提供的一个顶级项目。便捷的开发Spring框的的项目(提高效率)。基于**“约定大于配置”**的设计原则。Spring Boot提供了绝大多数的约定(如果没有配置,就基于默认的约定来设置相关项目需要的属性)。

1、Spring Boot优点

  • 快速集成框架:提供了启动添加依赖的功能,用于秒级集成各种框架(自动化配置)。如:添加Spring Boot支持的其它框架(如Spring-boot-driud-starter数据库连接池的框架,可以自动的帮助我们注册其中的Bean对象,完成数据库连接的配置)
  • 内置运行容器,无需配置Tomcat等Web容器,直接运行和部署。
  • 完全抛弃繁琐的XML,使用注解和配置的方式进行开发。(使用传统的Spring进行项目开发,会使用大量的xml文件,及文件内容)
  • 支持更多的监控指标,可以更好地了解项目的运行情况。(这是官方提供的一个专门监控Spring Boot项目的依赖包)。

2、创建Spring Boot

这里描述基于普通的maven项目进行搭建。

(1)创建一个普通的maven项目

(2)修改pom.xml文件,引入依赖

(3)准备SpringBoot的启动配置文件

(4)开发SpringBoot启动类

【代码如下】

package org.exmaple;
//必须在某个包下
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//SpringBoot的启动类注解
@SpringBootApplication
public class Application {
    public static void main(String[] args) {
        //基于SpringBoot的方式启动
        SpringApplication.run(Application.class,args);
    }
}

配置成功如下:

可以提供web静态资源,在resources目录下的public或者static文件夹中,访问时路径为资源路径,不需要添加public等文件夹路径。

url格式:http://ip:port/应用上下文路径/服务资源路径queryString

  • 应用上下文路径:Springboot中默认为“/”;
  • 服务资源路径:public和static下的文件,但不包含本身。

3、Spring Boot配置文件

(1)配置文件的作用

整个项目中所有重要的数据都是在配置文件中配置:

  • 数据库的连接信息(用户名和密码的设置);
  • 项目的启动端口;
  • 第三方系统的调用密钥等信息;
  • 用于发现和定位问题的普通日志和异常日志等。

配置文件在resources目录下,文件名为application,格式为properties/yml。(只能出现一个配置文件)

(2)properties文件格式

以键值对的形式进行配置(每个键值对一行),key和value之间使用“=”连接。键的多层级之间使用“."连接。

读取配置文件:

使用@Value注解来实现。使用${}格式读取。

@RestController
@RequestMapping("/user")
public class UserController {
    //@Value直接,使用${“配置项键名”},就可以将该键对应的值设置到属性中
    @Value("${server.port}")
    private String port;
    @RequestMapping("/port")
    public String port(){
        return port;
    }
}

上面将端口号改为8085,此时访问该路径显示端口号为8085.

(3)yml文件的格式

yml是树形结构的配置文件,基础语法“key: value”,**key和vlaue之间使用英文冒号加空格的方式组成,空格不可省略。**yml文件最大的优势是可以跨语言,不只是java中可以使用,golang、python都可以使用yml作为配置文件。

yml配置对象(这个时候就不能使用@Value来读取配置中的对象了,需要使用另一个注解@ConfigurationProperties来进行读取):

(4)properties vs yml

  • properties通过键值对的形式配置文件;yml使用类似于json格式的属性方式进行配置,层级之间使用换行缩进的方式配置,key和value之间使用英文冒号加空格的方式配置,空格不能省略。
  • properties为早期并且默认的配置文件的格式,但其配置存在一定的冗余数据,使用yml可以很好的解决数据冗余的问题。
  • yml通用性好,支持更多语言,如果是云服务器开发,可以使用yml配置文件作为1Java和go的共同配置文件。

二、Spring Boot日志框架

日志框架的作用:

  • 设置多种日志级别;
  • 打印时,指定不同的日志级别;
  • 输出到不同的地方:比如控制台、本地文件等。

不同的环境,需要不同的打印信息,如开发环境:需要打印一些调试信息:但生产环境(一般指linux服务器,运行项目,不需要观察控制台,日志一般输出到文件中),就不能打印这些调试信息。

1、java常见的日志框架

  • log4j=>apache提供的日志框架;
  • log4j2=>log4j的升级版本;
  • logback=>springboot默认的内置日志框架
  • slf4j=>日志的桥接框架(如果直接使用耨个日志框架的api,比如logback,那么之后要切换到lig4j,必须改代码,不太方便,,所以产生了slf4j这个桥接框架。基于slf4j的api来打印日志,之后,就可以无缝切换日志框架的具体实现了)。

2、日志级别

级别由低到高:

  • trace:微量,级别最低;
  • debug:需要调试时候的关键信息打印;
  • info:普通的打印信息;
  • warn:警告,不影响使用,但需要注意的问题;
  • error:错误信息,级别较高的错误日志信息;
  • fatal:致命的,因为代码异常导致程序退出执行的事件。

配置日志级别

#root,表示默认的所有的代码中,设置的打印级别
logging.level.root=INFO

#自定义某个包/某个类的打印级别(符合条件的就不在世root的级别)
#org.example.controller表示的这个包/类的打印级别自定义
lohhing.level.org.example.controller=debug

3、日志打印

使用日志对象,调用不同级别的打印方法(添加@Slf4j注解):

也可以使用字符串格式化的方式进行打印(变量替换占位符):

将日志保存到本地文件

# 设置日志文件的目录
logging:
  file:
    path: D:home
uoyi

# 设置日志文件的文件名
logging:
  file:
    name: D:home
uoyispring-1204.log

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值