Springboot静态资源与模板引擎Thymeleaf篇

一、导入静态资源

1.1 静态资源目录

  • 只要静态资源放在类路径下: /static or /public or /resources or /META-INF/resources
  • 访问 : 当前项目根路径/ + 静态资源名
  • 原理: 静态映射/**; "/**" 访问当前项目的任何资源 (静态资源的文件夹)
  • 请求进来,先去找Controller看能不能处理。不能处理的所有请求又都交给静态资源处理器。静态资源也找不到则响应404页面

源码解析

1.2自定义静态资源路径(一般不考虑)

我们也可以自己通过配置文件来指定一下,哪些文件夹是需要我们放静态资源文件的,在application.properties中配置;

spring.resources.static-locations=classpath:/coding/,classpath:/yanyu/

 改变默认存放静态资源的路径

spring:resources:static-locations: [classpath:/haha/]

 改变静态资源访问前缀

  • 默认无前缀
spring:mvc:static-path-pattern: /res/**访问地址:当前项目 + static-path-pattern + 静态资源名 = 静态资源文件夹下找的对应文件名

 这是一个Spring Boot应用程序的配置文件项,用于指定静态资源的加载路径。在这个例子中,有两个静态资源文件夹:classpath:/coding/classpath:/yanyu/。当访问这些路径时,Spring Boot会自动从类路径(classpath)下查找对应的资源文件。

 总结 

 1.在springboot,我们可以使用以下方式处理静态资源

  • Webjars localhost:8080/webjars/
  •  public,static,/**resources localhost:8080/

2.优先级:resources>static(默认)>public

1.3首页处理

欢迎页,静态资源文件夹下的所有 index.html 页面;被 /** 映射。

比如我访问  http://localhost:8080/ ,就会找静态资源文件夹下的 index.html

1.4网站图标处理

  • 图片文件名必须为favicon.ico
  • 图片文件必须放在静态资源目录下

1.5HTTP缓存机制

# 设置静态资源的最长存活时间
spring.resources.cache.cachecontrol.max-age=3600
# 设置静态资源的共享最长存活时间
spring.resources.cache.cachecontrol.s-maxage=3600

这是Spring Boot中的两个配置项,用于设置静态资源的缓存周期。

1. `spring.resources.cache.cachecontrol.max-age=3600`:这个配置项设置了静态资源的最长存活时间。在这个例子中,最长存活时间被设置为3600秒,即1小时。这意味着在这段时间内,浏览器可以访问已经缓存的静态资源,而不需要每次都去服务器获取。

2. `spring.resources.cache.cachecontrol.s-maxage=3600`:这个配置项设置了静态资源的共享最长存活时间。在这个例子中,共享最长存活时间也被设置为3600秒,即1小时。这意味着在这段时间内,所有用户共享同一个静态资源的缓存副本,而不是每个用户都有自己的副本。

#spring.web.resources.cache.period=3600

 这是Spring Boot中的一个配置项,用于设置静态资源的缓存周期。在这个例子中,缓存周期被设置为3600秒,即1小时。这意味着在这段时间内,浏览器可以访问已经缓存的静态资源,而不需要每次都去服务器获取。

#spring.web.resources.cache.use-last-modified=true

#使用资源1ast-modified时间,来对比服务器和浏览器的资源是否相同没有变化。相同返回304

spring.web.resources.cache.cachecontrol.cache-public=true

`spring.web.resources.cache.cachecontrol.cache-public=true` 是一个配置项,用于设置静态资源的缓存策略。当设置为 `true` 时,表示所有公共资源(如 CSS、JavaScript、图片等)都可以被浏览器缓存,以提高页面加载速度和用户体验。

1.6小技巧

dev-tools

  • 每次修改项目或者页面修改以后就不用重启项目了
  • 使用:Ctrl+F9(重构项目);
//导入依赖
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><optional>true</optional>
</dependency>

 二、模板引擎-Thymeleaf的使用

2.1相关配置

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>

2.2概述

Spring Boot支持多种模板引擎,包括Thymeleaf、FreeMarker、Velocity和Mustache等。这些模板引擎都可以与Spring Boot无缝集成,用于生成动态HTML页面。

Thymeleaf是Spring Boot官方推荐的模板引擎,它是一个现代化的服务器端Java模板引擎,使用自然模板语法简化模板设计和开发。Thymeleaf可以直接与Spring MVC集成,也可以与Spring WebFlux一起使用。

特点

  • 动静分离: Thymeleaf选用html作为模板页,这是任何一款其他模板引擎做不到的!Thymeleaf使用html通过一些特定标签语法代表其含义,但并未破坏html结构,即使无网络、不通过后端渲染也能在浏览器成功打开,大大方便界面的测试和修改。
  • 开箱即用: Thymeleaf提供标准和Spring标准两种方言,可以直接套用模板实现JSTL、 OGNL表达式效果,避免每天套模板、改JSTL、改标签的困扰。同时开发人员也可以扩展和创建自定义的方言。
  • Springboot官方大力推荐和支持,Springboot官方做了很多默认配置,开发者只需编写对应html即可,大大减轻了上手难度和配置复杂度。

 2.3源码解析

// 使用@ConfigurationProperties注解,将配置文件中的属性绑定到这个类的属性上
@ConfigurationProperties(prefix = "spring.thymeleaf"
)
public class ThymeleafProperties {// 定义一个静态常量DEFAULT_ENCODING,表示默认的字符编码private static final Charset DEFAULT_ENCODING;// 定义一个静态常量DEFAULT_PREFIX,表示默认的模板文件前缀public static final String DEFAULT_PREFIX = "classpath:/templates/";// 定义一个静态常量DEFAULT_SUFFIX,表示默认的模板文件后缀public static final String DEFAULT_SUFFIX = ".html";// 定义一个布尔类型的属性checkTemplate,表示是否检查模板文件是否存在private boolean checkTemplate = true;// 定义一个布尔类型的属性checkTemplateLocation,表示是否检查模板文件的位置是否正确private boolean checkTemplateLocation = true;// 定义一个字符串类型的属性prefix,表示模板文件的前缀private String prefix = "classpath:/templates/";// 定义一个字符串类型的属性suffix,表示模板文件的后缀private String suffix = ".html";// 定义一个字符串类型的属性mode,表示模板引擎的模式,默认为HTML模式private String mode = "HTML";// 定义一个Charset类型的属性encoding,表示模板文件的字符编码private Charset encoding;
}

我们可以在其中看到默认的前缀和后缀!

我们只需要把我们的html页面放在类路径下的templates下,thymeleaf就可以帮我们自动渲染了。

使用thymeleaf什么都不需要配置,只需要将他放在指定的文件夹下即可

 2.4测试

2.4.1简单测试1

后端

package com.yanyu.springplustest4;import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;@Controller
public class TestController {@RequestMapping("/t1")public String test1(){//classpath:/templates/test.htmlreturn "test";}}

前端

 test.html 放在 templates 目录下

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<h1>测试页面</h1></body>

2.4.2简单测试2 th:text

咱们在项目的resources目录下的templates文件夹下面创建一个叫index.html的文件,咱们在这个html文件中的<html>标签修改为<html xmlns:th="http://www.thymeleaf.org">这样在Thymeleaf中就可以使用Thymeleaf的语法和规范啦。
后端

package com.yanyu.springplustest4;import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;@Controller
public class urlController {@GetMapping("t2")//页面的url地址public String getindex(Model model)//对应函数{model.addAttribute("name","bigsai");return "test2";//与templates中index.html对应}
}

前端

<!DOCTYPE html>
<html  xmlns:th="http://www.thymeleaf.org">
<head><meta charset="UTF-8"><title>title</title>
</head>
<body>
hello 第一个Thymeleaf程序
<div th:text="${name}">name是bigsai(我是离线数据)</div>
</body>
</html>

2.5Thymeleaf语法详解

配置详解

Springboot官方对Thymeleaf做了很多默认配置,但咱们引入Thymeleaf的jar包依赖后很可能根据自己特定需求进行更细化的配置,例如页面缓存、字体格式设置等等。

Springboot官方提供的配置内容有以下:

# THYMELEAF (ThymeleafAutoConfiguration)spring.thymeleaf.cache=true# 是否启用模板缓存spring.thymeleaf.check-template=true# 在渲染模板之前检查模板是否存在spring.thymeleaf.check-template-location=true # 在渲染模板之前检查模板位置是否存在spring.thymeleaf.enabled=true # 是否为Web框架启用Thymeleaf视图解析spring.thymeleaf.enable-spring-el-compiler=false # 在SpringEL表达式中启用SpringEL编译器spring.thymeleaf.encoding=UTF-8 # 模板文件的编码spring.thymeleaf.excluded-view-names= # 从解析中排除的视图名称(允许的模式)列表spring.thymeleaf.mode=HTML # 应用于模板的模式spring.thymeleaf.prefix=classpath:/templates/ # 构建URL时附加到视图名称的前缀# 当设置最大块大小时,仅在CHUNKED模式下执行的视图名称(模式)列表
spring.thymeleaf.reactive.chunked-mode-view-names=# 即使设置了最大块大小,也应在FULL模式下执行的视图名称(模式)列表
spring.thymeleaf.reactive.full-mode-view-names=spring.thymeleaf.reactive.max-chunk-size=0 # 用于写入响应的数据缓冲区的最大大小(字节)spring.thymeleaf.reactive.media-types= # 视图技术支持的媒体类型spring.thymeleaf.servlet.content-type=text/html # 写入HTTP响应的Content-Type值spring.thymeleaf.suffix=.html # 构建URL时附加到视图名称的后缀spring.thymeleaf.template-resolver-order= # 链中的模板解析器顺序spring.thymeleaf.view-names= # 可以解析的视图名称(模式)列表

比如spring.thymeleaf.cache=false是否允许页面缓存的配置,我们在开发时候要确保页面是最新的所以需要禁用缓存;而在上线运营时可能页面不常改动为了减少服务端压力以及提升客户端响应速度会允许页面缓存的使用。

常用标签 

咱们上面知道Thymeleaf通过特殊的标签来寻找属于Thymeleaf的部分,并渲染该部分内容,而除了上面展示过的th:text之外还有很多常用标签,并且Thymeleaf也主要通过标签来识别替换对应位置内容,Thymeleaf标签有很多很多,功能也很丰富,这里列举一些比较常用的标签如下:

标签作用示例
th:id替换id<input th:id="${user.id}"/>
th:text文本替换<p text:="${user.name}">bigsai</p>
th:utext支持html的文本替换<p utext:="${htmlcontent}">content</p>
th:object替换对象<div th:object="${user}"></div>
th:value替换值<input th:value="${user.name}" >
th:each迭代<tr th:each="student:${user}" >
th:href替换超链接<a th:href="@{index.html}">超链接</a>
th:src替换资源<script type="text/javascript" th:src="@{index.js}"></script>
 简单测试3 

后端

数据层

package com.yanyu.springplustest4.dto;import lombok.Data;import java.util.List;
@Data
public class User {private int id;private String name;private boolean active;private List<String> students;}

控制层 

package com.yanyu.springplustest4.Controller;import com.yanyu.springplustest4.dto.User;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;import java.util.Arrays;@Controller
public class UserController {@GetMapping("/user")public String getUser(Model model) {User user = new User();user.setId(1);user.setName("John Doe");user.setActive(true);user.setStudents(Arrays.asList("Alice", "Bob", "Charlie"));model.addAttribute("user", user);model.addAttribute("msg","Hello,Thymeleaf");return "user";}
}

前端

<!-- DOCTYPE html -->
<html xmlns:th="http://www.thymeleaf.org">
<head><title>User Page</title>
</head>
<body>
<!-- 表单提交,action指向/user,object绑定到user对象 -->
<form method="post" th:action="@{/user}" th:object="${user}"><!-- 输入框,id绑定到user的id属性,value绑定到user的name属性,name属性为name --><input th:id="${user.id}" th:value="${user.name}" name="name" /><!-- 显示用户姓名 --><p th:text="${user.name}">bigsai</p><!-- 显示消息内容 --><p th:utext="${msg}">content</p><!-- 显示user对象的内容 --><div th:object="${user}"></div><!-- 输入框,值为user的name属性 --><input th:value="${user.name}" ><!-- 表格,遍历user的students属性 --><table><tr th:each="student : ${user.students}"><!-- 显示学生姓名 --><td th:text="${student}">Student Name</td></tr></table><!-- 链接,指向index.html --><a th:href="@{index.html}">Link</a><!-- 提交按钮 --><button type="submit">Update</button><!-- 如果user的active属性为true,则显示取消激活按钮,调用deactivateUser方法并传入user的id属性 --><button type="button" th:if="${user.active}" th:"deactivateUser(${user.id})">Deactivate</button>
</form>
</body>
</html>

在这个示例中,当访问/user路径时,UserController会将一个User对象添加到Model中,然后返回user.html模板文件。在user.html中,利用Thymeleaf的th:id属性替换了input标签的id属性,使得input标签的id值根据User对象的id属性动态变化。同时,form标签的method属性设置为post,action属性设置为"/user",表示表单提交的目标地址为UserController的updateUser方法。在表单中,利用name属性指定了表单项的名称,使得在提交表单时可以正确地绑定到User对象的属性上。

 链接表达式: @{…}

引入css
 <link rel="stylesheet" th:href="@{index.css}">
引入JavaScript:
 <script type="text/javascript" th:src="@{index.js}"></script>
超链接:
<a th:href="@{index.html}">超链接</a>

变量表达式: ${…}

 简单测试4

在Thymeleaf中可以通过${…}进行取值,这点和ONGL表达式语法一致。
例如咱们创建这么一个对象:

package com.yanyu.springplustest4.dto;import lombok.Data;@Data
public class user {private String name;private  int age;private  String detail;}

控制层

package com.yanyu.springplustest4.Controller;import com.yanyu.springplustest4.dto.user1;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.GetMapping;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;@Controller
public class UserControlle1 {@GetMapping("/user1")//页面的url地址public String getindex(Model model)//对应函数{user1 user1=new user1("bigsai",22,"一个幽默且热爱java的社会青年");List<String> userList=new ArrayList<>();userList.add("zhang san 66");userList.add("li si 66");userList.add("wang wu 66");Map<String ,String> map=new HashMap<>();map.put("place","博学谷");map.put("feeling","very well");//数据添加到model中model.addAttribute("name","bigsai");//普通字符串model.addAttribute("user",user1);//储存javabeanmodel.addAttribute("userlist",userList);//储存Listmodel.addAttribute("map",map);//储存Mapreturn "user1";//与templates中index.html对应}}

取普通字符串:
如果在controller中的Model直接存储某字符串,我们可以直接${对象名}进行取值。完整代码如下:

<h2>普通字符串</h2>
<table border="0"><tr><td th:text="'我的名字是:'+${name}"></td></tr>
</table>


取JavaBean对象:
取JavaBean对象也很容易,因为JavaBean自身有一些其他属性,所以咱们就可以使用${对象名.对象属性}或者${对象名['对象属性']}来取值,这和JavaScript语法是不是很相似呢!除此之外,如果该JavaBean如果写了get方法,咱们也可以通过get方法取值例如${对象.get方法名}完整代码如下:

<h2>JavaBean对象</h2>
<table bgcolor="#ffe4c4" border="1"><tr><td>介绍</td><td th:text="${user.name}"></td></tr><tr><td>年龄</td><td th:text="${user['age']}"></td></tr><tr><td>介绍</td><td th:text="${user.getDetail()}"></td></tr>
</table>

取List集合(each):

因为List集合是个有序列表,里面内容可能不止一个,你需要遍历List对其中对象取值,而遍历需要用到标签:th:each,具体使用为<tr th:each="item:${userlist}">,其中item就相当于遍历每一次的对象名,在下面的作用域可以直接使用,而userlist就是你在Model中储存的List的名称。完整的代码为

<h2>List取值</h2>
<table bgcolor="#ffe4c4" border="1"><tr th:each="item:${userlist}"><td th:text="${item}"></td></tr>
</table>

直接取Map:

很多时候我们不存JavaBean而是将一些值放入Map中,再将Map存在Model中,我们就需要对Map取值,对于Map取值你可以${Map名['key']}来进行取值。也可以通过${Map名.key}取值,当然你也可以使用${map.get('key')}(java语法)来取值,完整代码如下:

<h2>Map取值</h2>
<table bgcolor="#8fbc8f" border="1"><tr><td>place:</td><td th:text="${map.get('place')}"></td></tr><tr><td>feeling:</td><td th:text="${map['feeling']}"></td></tr>
</table>

遍历Map:

如果说你想遍历Map获取它的key和value那也是可以的,这里就要使用和List相似的遍历方法,使用th:each="item:${Map名}"进行遍历,在下面只需使用item.keyitem.value即可获得值。完整代码如下:

<h2>Map遍历</h2>
<table bgcolor="#ffe4c4" border="1"><tr th:each="item:${map}"><td th:text="${item.key}"></td><td th:text="${item.value}"></td></tr>
</table>

选择变量表达式: *{…}

变量表达式不仅可以写成${…},而且还可以写成*{…}。

但是,有一个重要的区别:星号语法对选定对象而不是整个上下文评估表达式。也就是说,只要没有选定的对象,美元(${…})和星号(*{...})的语法就完全一样。

什么是选定对象?使用th:object属性的表达式的结果。就可以选定对象,具体实例

<!-- 使用Thymeleaf模板引擎,将user对象绑定到div元素上 -->
<div th:object="${user}"><!-- 显示用户姓名,如果不存在则显示默认值"赛" --><p>Name: <span th:text="*{name}">赛</span>.</p><!-- 显示用户年龄,如果不存在则显示默认值"18" --><p>Age: <span th:text="*{age}">18</span>.</p><!-- 显示用户的详细信息,如果不存在则显示默认值"好好学习" --><p>Detail: <span th:text="*{detail}">好好学习</span>.</p>
</div>

消息表达: #{…}

文本外部化是从模板文件中提取模板代码的片段,以便可以将它们保存在单独的文件(通常是.properties文件)中,文本的外部化片段通常称为“消息”。通俗易懂的来说#{…}语法就是用来读取配置文件中数据的。在Thymeleaf你可以使用#{...}语法获取消息,具体实例代码如下:

首先在templates目录下建立home.properties中写入以下内容:

bigsai.nane=bigsai
bigsai.age=22
province=Jiang Su

application.properties中加入以下内容:

spring.messages.basename=templates/home

这样我们就可以在Thymeleaf中读取配置的文件了,完整代码如下:

<h2>消息表达</h2>
<table bgcolor="#ffe4c4" border="1"><tr><td>name</td><td th:text="#{bigsai.name}"></td></tr><tr><td>年龄</td><td th:text="#{bigsai.age}"></td></tr><tr><td>province</td><td th:text="#{province}"></td></tr>
</table>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/579014.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Arduino平台软硬件原理及使用——按键模块(下拉电阻电路)的使用

文章目录 一、上拉电阻电路 二、下拉电阻电路 二、按键模块在Arduino中的使用 一、上拉电阻电路 如上图为上拉电阻电路的按键原理&#xff0c;VCC及GND分别为正负极&#xff0c;PIN接信号端口&#xff1b; 此时可实现的功能为&#xff1a; 按键未按下时PIN接收高电平信号&#…

知乎冷门蓝海项目,零门槛教你如何单日变现200+

顺哥轻创资源网 shundazy1 一、项目介绍&#xff1a; 通过知乎平台上传相关资料作品 用文章内容吸引用户&#xff0c;随后会下载我们准备好的资料作品 用户下载资料后&#xff0c;我们即可通过资料变现 总结起来就是软文引流配合链接变现的模式 我们团队实操下来单号每日…

智能监控平台/视频共享融合系统EasyCVR点击通道后页面分页不显示是什么原因?如何解决?

TSINGSEE青犀视频监控汇聚平台EasyCVR可拓展性强、视频能力灵活、部署轻快&#xff0c;可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等&#xff0c;以及支持厂家私有协议与SDK接入&#xff0c;包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安防视频监控的能力&…

API文档生成!超好用API调试工具

在数字化时代&#xff0c;API已经成为了应用程序之间进行通信的关键桥梁。随着API的普及和复杂性的增加&#xff0c;API研发和管理也面临着越来越多的挑战。为了更好地应对这些挑战&#xff0c;Apipost提供了一整套API研发工具&#xff0c;包括API设计、API调试、API文档和API自…

【算法学习】斐波那契数列模型-动态规划

前言 我在算法学习过程中&#xff0c;针对斐波那契数列模型的动态规划的例题进行了一个整理&#xff0c;并且根据标准且可靠一点的动态规划解题思路进行求解类似的动归问题&#xff0c;来达到学习和今后复习的必要。 所谓的斐波那契数列模型&#xff0c;即当前状态的值等于前两…

鸿蒙原生应用/元服务开发-Stage模型能力接口(十)上

ohos.app.form.FormExtensionAbility (FormExtensionAbility) FormExtensionAbility为卡片扩展模块&#xff0c;提供卡片创建、销毁、刷新等生命周期回调。 本模块首批接口从API version 9开始支持。后续版本的新增接口&#xff0c;采用上角标单独标记接口的起始版本。本模块接…

odoo17核心概念view5——ir_ui_view.py

这是view系列的第5篇文章&#xff0c;介绍一下view对应的后端文件ir_ui_view.py&#xff0c;它是base模块下的一个文件 位置&#xff1a;odoo\addons\base\models\ir_ui_view.py 该文件一共定义了三个模型 1.1 ir.ui.view.custom 查询数据库这个表是空的&#xff0c;从名字看…

云原生Kubernetes:K8S集群实现容器运行时迁移(docker → containerd) 与 版本升级(v1.23.14 → v1.24.1)

目录 一、理论 1.K8S集群升级 2.环境 3.升级策略 4.master1节点迁移容器运行时(docker → containerd) 5.master2节点迁移容器运行时(docker → containerd) 6.node1节点容器运行时迁移(docker → containerd) 7.升级集群计划&#xff08;v1.23.14 → v1.24.1&#…

接口文档设计的12个注意点

我们做后端开发的,经常需要定义接口文档。 最近在做接口文档评审的时候&#xff0c;发现一个小伙伴定义的出参是个枚举值&#xff0c;但是接口文档没有给出对应具体的枚举值。其实&#xff0c;如何写好接口文档&#xff0c;真的很重要。今天我给你带来接口文档设计的12个注意点…

OpenCV数字图像处理——基于目标边缘适用于目标部分遮挡或不同光照模板匹配

简介 模板匹配是一种常见的计算机视觉问题&#xff0c;通常用于在一张图像中查找特定的模板图像。在处理模板匹配时&#xff0c;经常会面临对象的姿态未知的情况&#xff0c;其中姿态包括位置&#xff08;X&#xff0c;Y坐标&#xff09;和旋转角度&#xff08;θ&#xff09;…

C++继承与派生——(3)公有继承的访问权限的变化

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 缺乏明确的目标&#xff0c;一生将庸庸…

linux cpu调度分析

一、cpu调度调试方法 echo 0 > /sys/kernel/debug/tracing/tracing_on echo > /sys/kernel/debug/tracing/trace echo 30720 > /sys/kernel/debug/tracing/buffer_size_kb echo nop > /sys/kernel/debug/tracing/current_tracer echo sched_switch sched_wakeup s…

Python 基础面试第三弹

1. 获取当前目录下所有文件名 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 import os def get_all_files(directory): file_list []<br> # <code>os.walk</code>返回一个生成器&#xff0c;每次迭代时返回当前目录路径、子目录列表和文件列表 for…

闲来无事,使用C++和代理IP采集天气预报信息

目录 一、引言 二、代理IP原理 三、选择合适的代理IP服务 四、C程序实现 五、测试与优化 六、结论 一、引言 在当今的互联网时代&#xff0c;网络信息的获取变得日益重要。天气预报信息作为日常生活的重要参考&#xff0c;其获取方式也随着技术的发展而不断变化。在本文…

JVisualVM工具的使用⭐️并使用自带JDBC监控sql语句执行时间记录

小伙伴们大家好&#xff0c;今天使用了继Jconsole工具之外的另一个JDK自带的性能分析工具 目录 一、JVisualVm 简介 二、使用 三、菜单使用 章末 一、JVisualVm 简介 JVisualVM是Java VisualVM的简称&#xff0c;是一个集成了多个 JDK 自带监控和故障处理工具的图形化工具…

MySQL的替换函数及补全函数的使用

前提&#xff1a; mysql的版本是8.0以下的。不支持树形结构递归查询的。但是&#xff0c;又想实现树形结构的一种思路 提示&#xff1a;如果使用的是MySQL8.0及其以上的&#xff0c;想要实现树形结构&#xff0c;请参考&#xff1a;MySQL数据库中&#xff0c;如何实现递归查询…

基于BaseHTTPRequestHandler的HTTP服务器基础实现

1. BaseHTTPRequestHandler介绍 BaseHTTPRequestHandler是Python中的一个基类&#xff0c;属于http.server模块&#xff0c;用于处理HTTP请求的基本功能。它提供了处理常见HTTP请求方法&#xff08;如GET、POST等&#xff09;的默认实现&#xff0c;并允许你在子类中进行定制化…

2024年【道路运输企业安全生产管理人员】考试题及道路运输企业安全生产管理人员报名考试

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 道路运输企业安全生产管理人员考试题考前必练&#xff01;安全生产模拟考试一点通每个月更新道路运输企业安全生产管理人员报名考试题目及答案&#xff01;多做几遍&#xff0c;其实通过道路运输企业安全生产管理人员…

day42 1226

作业1&#xff1a; #include <iostream>using namespace std;namespace myspace {string str; }int length(string str) {//char *p &str.at(0);const char *p str.data();int count 0;while (*p ! 0) {p;count;}return count; } int main() {getline(cin,myspac…

2023年数据泄露态势年度报告

为了掌握数据泄露态势&#xff0c;应对日益复杂的安全风险&#xff0c;零零信安基于0.zone安全开源情报系统&#xff0c;发布《数据泄露态势》年度报告。该系统监控范围包括明网、深网、暗网、匿名社群等约10万个威胁源。除此之外还会针对一些典型的数据泄露事件进行抽样事件分…