SpringBoot简单尝试

时间:2021-04-08 14:09:17   收藏:0   阅读:0

一、spring boot核心

配置在类路径下autoconfigure下(多瞅瞅)

@SpringBootApplication里的重要注解(@Configuration,@EnableAutoConfiguration,@ComponentScan三个注解的组合。)

	@ComponentScan:默认就会装配标识了@Controller/@Service/@Component/@Repository注解的类到spring容器中
	
		@Component是一个元注解,意思是可以注解其他类注解泛指组件,当组件不好归类的时候,我们可以使用这个
		
		我们可以使用这个注解进行标注,作用就相当于XML配置<bean id="" class=""></bean>

	@EnableAutoConfiguration: 开启自动装配
	
		@AutoConfigurationPackage:自动配置包
		
			@Import({Registrar.class}):给容器中导入组件(扫描启动类同级的包及子包的所有组件扫描到spring容器中)
                                                (规定包只能在启动类同级目录)
												
		@Import({AutoConfigurationImportSelector.class}):导入容器所需要的组件,并配置好组件(使用x组件,配置好x)

	@SpringBootConfiguraztion: 支持JavaConfig的方式来进行配置(使用Configuration配置类等同于XML文件)。
	
		@Configuration:	@configuration标注配置类 = mvc写的配置文件(也是组件)
		
		@Component:		说明是一个spring组件

Springboot在启动时候从类路径的 META-INF/spring.factories 中获取EnableAutoConfiguration指定的值,将这些值
作为自动配置类导入到容器中

二、springboot配置(约定大于配置)

1、基本配置

(1)、POM
//启动器 都以spring-boot-starter开头不用写版本,有版本管理库,定义spring的应用场景,下面是springboot在web的应用场景
(导入web环境所有依赖)
//官网有各种启动器   可以查看pom首个parent(groupId)=》parent(groupId)=》parent 就是springboot版本管理 
//									(没有的需要手动声名版本)
//可以进去看启动器的具体场景应用依赖
<dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
</dependency>

(2)、静态资源配置
搜索查看WebMvcAutoConfiguration配置类即可看到添加资源处理器(addResourceHandlers),根据源码可以在resources下
创建public和resources优先级为(public < static < resources)

(3)、Ico图标配置
放在static下即可加载

(4)、404,500配置
在templates下创建error文件夹里面放404.html 500.html即可

2、自定义配置(Yml)

//基本语法
yaml:
    person:
    age: 18
    name: 张三
    lis:
        - 第一个
        - 第二个
    mas: {money: 9999999}
    veges:
        color:  绿色
        type: 黄瓜

    指定开发环境:
        1.spring.profiles.active=dev/*激活application-dev.properties*/
        2.yml支持文档块,以---(三个减号)回车分模块  spring:profiles:dev
            spring:profiles:active: dev
    配置文件优先级:
        classpath:==》classpath:config/ ==》file:/==》file:config/

3、日志配置

(1)、POM日志简单配置
logging.file.path:d:/mine	//保存日志
logging.pattern.console		//控制台输入日志格式
logging.pattern.file		//保存日志时候日志的格式
//yml
#指定日志等级并保存日志到path	不加字符直接写格式报错
logging:
  file:
    path: d:/logs
  level:
    cn.bdqn: info
  pattern:
    console: 日志:%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
    file: 日志:%msg%n

(2)、日志格式
%d表示日期时间
%thread表示线程名
%-5level:级别从左显示5个字符宽度
%logger{50}表示logger名字最长50个字符,否则按照句点分割
%msg:日志消息
%n:换行符
%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{50} - %msg%n
                                        属性	解释
logging.config=	日志配置文件的位置。例如,classpath:logback.xml。
logging.exception-conversion-word=%wEx	转换异常时使用的转换字。
logging.file=	设置保存日志的日志文件
logging.file.max-history=0	are neat
logging.file.max-size=10MB	设置日志文件最大大小
logging.level.(cn.bdqn)=	设置日志等级
logging.path=	日志文件的位置,例如/var/log
logging.pattern.console=	定义打印的日志格式
logging.pattern.dateformat=yyyy-MM-dd HH:mm:ss.SSS	设置日志日期格式
logging.pattern.file=	定义输出到日志文件的日志格式
logging.register-shutdown-hook=false	当初始化日志系统时,为其注册一个关闭钩子。

4、热部署

热部署				//老实讲,这个玩意有问题,好多时候网页会出错。
先上原理
	深层原理是使用了两个ClassLoader,一个Classloader加载那些不会改变的类(第三方Jar包),另一个ClassLoader
加载会更改的类称为restart ClassLoader,这样在有代码更改的时候,原来的restart ClassLoader 被丢弃,重新创建一个
restart ClassLoader,由于需要加载的类相比较少,所以实现了较快的重启时间。
(1)修改pom文件
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
            <scope>runtime</scope>
        </dependency>

(2)maven插件设置参数也就是在maven打包插件加一个configurattion
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                    <configuration>
                        <fork>true</fork>
                        <addResources>true</addResources>
                    </configuration>
                </plugin>
            </plugins>
        </build>

(3)编译设置:File->Settings->Build,Execution,Deployment->Compiler:选中 Build project automatically

(4)运行设置:ctrl+shift+a 调起搜索,输入registry,点击第一项,打开Registry编辑框,选中compiler.automake
.allow.when.app.running

**网页热部署**
  spring:
    thymeleaf:
      cache: false

三、模板引擎thymeleaf

1、常用的th标签

关键字 功能介绍 案例
th:id 替换id <input th:id="‘xxx‘ + ${collect.id}"/>
th:text 文本替换 <p th:text="${collect.description}">description</p>
th:utext 支持html的文本替换 <p th:utext="${htmlcontent}">conten</p>
th:object 替换对象 <div th:object="${session.user}">
th:value 属性赋值 <input th:value="${user.name}" />
th:with 变量赋值运算 <div th:with="isEven=${prodStat.count}%2==0"></div>
th:style 设置样式 th:style="‘display:‘ + @{(${sitrue} ? ‘none‘ : ‘inline-block‘)} + ‘‘"
th:onclick 点击事件 th:onclick="‘getCollect()‘"
th:each 属性赋值 tr th:each="user,userStat:${users}">
th:if 判断条件 <a th:if="${userId == collect.userId}" >
th:unless 和th:if判断相反 <a th:href="@{/login}" th:unless=${session.user != null}>Login</a>
th:href 链接地址 <a th:href="@{/login}" th:unless=${session.user != null}>Login</a> />
th:switch 多路选择 配合th:case 使用 <div th:switch="${user.role}">
th:case th:switch的一个分支 <p th:case="‘admin‘">User is an administrator</p>
th:fragment 布局标签,定义一个代码片段,方便其它地方引用 <div th:fragment="alert">
th:include 布局标签,替换内容到引入的文件 <head th:include="页面名字:: 使用页面定义的名字" th:with="title=‘xx‘"></head> />
th:replace 布局标签,替换整个标签到引入的文件 <div th:replace="fragments/header :: title"></div>
th:selected selected选择框 选中 th:selected="(${xxx.id} == ${configObj.dd})"
th:src 图片类地址引入 <img class="img-responsive" alt="App Logo" th:src="@{/img/logo.png}" />
th:inline 定义js脚本可以使用变量 <script type="text/javascript" th:inline="javascript">
th:action 表单提交的地址 <form action="subscribe.html" th:action="@{/subscribe}">
th:remove 删除某个属性 <tr th:remove="all">
1.all:删除包含标签和所有的孩子。
2.body:不包含标记删除,但删除其所有的孩子。
3.tag:包含标记的删除,但不删除它的孩子。
4.all-but-first:删除所有包含标签的孩子,除了第一个。
5.none:什么也不做。这个值是有用的动态评估。
th:attr 设置标签属性,多个属性可以用逗号分隔 比如 th:attr="src=@{/image/aa.jpg},title=#{logo}",此标签不太优雅,一般用的比较少。

2、thymeleaf引入操作

<!--引入动态-->
<script th:src="@{/webjars/jquery/3.5.1/dist/jquery.js}"></script>

<!--引入静态-->
<img th:src="@{/images/tianshi.png}">

<!--背景url-->
<ul th:style="‘background-image: url(‘+@{/images/tupian.png}+‘);‘">

<!--a标签 通过controller解析-->
<a th:href="${#httpServletRequest.getContextPath()+‘/story/chongzhi‘}"</a>
<a th:href="@{/story/cz(id=1,money=999.0)}">屠龙宝刀,点击就送</a>

<!--拼接图片-->
<img th:src="${#httpServletRequest.getContextPath()+‘/images/‘+giveGift.giftImg}">

<!--传递a=1 controller接受也必须int a-->
<!--不行就重启-->
<div class="c_b_p_desc" th:utext="${pageInfo.say}+‘<a class=c_b_p_desc_readmore href=‘+@{note(url=${pageInfo.url})}+‘>
阅读全文‘">‘"</div>

3、thymeleaf展示数据

<!--a+span-->
<a th:each="AnimeType : ${listAnimeType}" href="">
       <span th:text="${AnimeType.animeTypeName}"></span>
</a>

<!--a+Table-->
<table>
    <tr th:each="Vote : ${listVotePerson}">
        <a th:text="${Vote.voteTitle}"></a>
    </tr>
</table>

<!--遍历单个数据(不用th:each)--->
<span th:text="${voteNeeds.get(0).vote.voteTitle}"></span>

<!--格式化LocalDateTime)--->
${#temporals.format(pageInfo.riqi, ‘yyyy-MM-dd HH:mm‘)}
评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2
迷上了代码!