Halo(五)
ApplicationPreparedEvent 监听事件
Event published once the application context has been refreshed but before any
{@link ApplicationRunner application} and {@link CommandLineRunner command line}
runners have been called.
Spring Boot 2.0 版本中所有的事件按执行的先后顺序如下:
ApplicationStartingEvent
ApplicationEnvironmentPreparedEvent
ApplicationPreparedEvent
ApplicationStartedEvent <= 新增的事件
ApplicationReadyEvent
ApplicationFailedEvent
@Configuration
@Order(Ordered.HIGHEST_PRECEDENCE) //最高优先级,最先执行
public class StartedListener implements ApplicationListener<ApplicationStartedEvent> {
@Override
public void onApplicationEvent(ApplicationStartedEvent event) {
//打印博客地址
this.printStartInfo();
//初始化主题
this.initThemes();
}
}
Path、Paths、Files
Path类可用于在文件系统中定位文件的对象,它通常表示系统相关的文件路径:
getRoot() //返回此路径的根组分作为 Path 对象,或 null(如果该路径不具有根组件)("E:\迅雷下载"返回"E:\")
toAbsolutePath() //返回表示此路径的绝对路径的 Path 对象
getNameCount() //返回路径中的名称元素的数量("E:\迅雷下载"返回"1")
resolve()
把当前路径当成父目录,而把参数中的路径当成子目录或是其中的文件,进行解析之后得到一个新路径。
resolveSibling()
方法的作用与 resolve 方法类似,只不过把当前路径的父目录当成解析时的父目录。
relativize()
方法的作用与 resolve 方法正好相反,用来计算当前路径相对于参数中给出的路径的相对路径。
subpath()
方法用来获取当前路径的子路径,参数中的序号表示的是路径中名称元素的序号。
startsWith()和endsWith()
方法用来判断当前路径是否以参数中的路径开始或结尾。
在一般的路径中,“.”和“..”分别用来表示当前目录和上一级目录。
Path path1 = Paths.get("folder1", "sub1");
Path path2 = Paths.get("folder2", "sub2");
path1.resolve(path2); folder1\sub1\folder2\sub2
path1.resolveSibling(path2); folder1\folder2\sub2
path1.relativize(path2); ..\..\folder2\sub2
path1.subpath(0, 1); folder1
path.normalize()
normalize()方法可以标准化路径,它会处理路径中的相对路径,去除"."".."
原:path = c:\ld\.\test
新:path = c:\ld\test
public final class Paths {
private Paths() {}
//将路径字符串或连接到路径字符串的字符串序列转换为 Path
public static Path get(String first, String... more) {
return Path.of(first, more);
}
//将给定的URI转换为Path对象
public static Path get(URI uri) {
return Path.of(uri);
}
}
Files工具类:
旧的IO中的操作文件的类是File,但是File类只能操作文件(创建,删除,修改属性等),但是不能修改文件的内容。
Files工具类可以直接写文件。
File工具类通常需要结合Path对象来使用:
拷贝文件
copy(...) 有3个重载方法,通常需要跟Path结合使用
操作文件
createDirectories(Path dir, FileAttribute<?>... attrs) //首先创建所有不存在的父目录来创建目录
createDirectory(Path dir, FileAttribute<?>... attrs) //创建一个新的目录
createFile(Path path, FileAttribute<?>... attrs) //创建一个新的和空的文件,如果该文件已存在则失败
delete(Path path) //删除文件
判断属性
isHidden(Path path) //告知文件是否被 隐藏
isReadable(Path path) //测试文件是否可读
isDirectory(Path path, LinkOption... options) //测试文件是否是目录
复制文件夹及文件(Files)
package java.nio.file.Files:
public static Path walkFileTree(Path start, FileVisitor<? super Path> visitor)
1) 在旧版本中遍历文件系统只能通过递归的方法来实现,但是这种方法不仅消耗资源大而且效率低
2) NIO.2 的 Files 工具类提供了一个静态工具方法 walkFileTree 来高效并优雅地遍历文件系统
3) walkFileTree:
i. 表示从start代表的节点开始遍历文件系统;
ii. 其中visitor是遍历过程中的行为控制器;
public class FileUtils {
private FileUtils() {
}
public static void copyFolder(Path source,Path target) throws IOException {
Files.walkFileTree(source, new SimpleFileVisitor<Path>() {
private Path current;
/**
* 接口方法的返回值 FileVisitResult 是一个枚举类型,
* walkFileTree 会根据这个返回值决定是否要继续遍历下去,
* 如果要继续遍历,它总共有4个枚举值:都是 FileVisitResult 中定义的枚举值
*
* CONTINUE:继续遍历
*
* SKIP_SIBLINGS:继续遍历,但忽略当前节点的所有兄弟节点直接返回上一层继续遍历
*
* SKIP_SUBTREE:继续遍历,但是忽略子目录,但是子文件还是会访问
*
* TERMINATE:终止遍历
*/
//访问一个目录前(dir:正在访问的绝对路径目录)
@Override
public FileVisitResult preVisitDirectory(Path dir, BasicFileAttributes attrs) throws IOException {
//截取相对路径( source.relativize(dir) ),拼接到目标目录( target.resolve(dir) )
current = target.resolve(source.relativize(dir).toString());
//创建目标文件夹,并继续
Files.createDirectories(current);
return FileVisitResult.CONTINUE;
}
//正在访问一个文件时(file:正在访问的绝对路径文件)
@Override
public FileVisitResult visitFile(Path file, BasicFileAttributes attrs) throws IOException {
//复制文件
Files.copy(file, target.resolve(source.relativize(file).toString()), StandardCopyOption.REPLACE_EXISTING);
return FileVisitResult.CONTINUE;
}
});
}
}
递归删除文件夹
public static void deleteFolder(Path deletingPath) throws IOException {
if (Files.notExists(deletingPath)) {
return;
}
org.eclipse.jgit.util.FileUtils.delete(deletingPath.toFile(),
org.eclipse.jgit.util.FileUtils.RECURSIVE | org.eclipse.jgit.util.FileUtils.RETRY);
}
FileUtils
创建临时目录:
public static Path createTempDirectory() throws IOException {
//创建前缀为"halo"的临时目录
return Files.createTempDirectory("halo");
}
检查给定路径是否为空:
public static boolean isEmpty(Path path) throws IOException {
//不是目录或者不存在,返回true
if (!Files.isDirectory(path) || Files.notExists(path)) {
return true;
}
/**
* Files.list(path)
* 返回的元素是一个惰性填充的流(非递归)
* 流的元素是Path对象
*/
try (Stream<Path> pathStream = Files.list(path)) {
//判断是否是空目录
return pathStream.count() == 0;
}
}
将ZipInputStream解压缩到目标路径:
public static void unzip(ZipInputStream zis, Path targetPath) throws IOException {
//创建目标路径(如果路径不存在)
if (Files.notExists(targetPath)) {
Files.createDirectories(targetPath);
}
//目标路径必须为空
mustBeEmpty(targetPath);
ZipEntry zipEntry = zis.getNextEntry();
while (zipEntry != null) {
//合并路径
Path entryPath = targetPath.resolve(zipEntry.getName());
//检查目录(判断entryPath是否以targetPath开头)
FileUtils.checkDirectoryTraversal(targetPath, entryPath);
if (zipEntry.isDirectory()) {
//创建目录
Files.createDirectories(entryPath);
} else {
//复制文件
Files.copy(zis, entryPath);
}
zipEntry = zis.getNextEntry();
}
}
Halo(五)的更多相关文章
- Halo 开源项目学习(五):评论与点赞
基本介绍 博客系统中,用户浏览文章时可以在文章下方发表自己的观点,与博主或其他用户进行互动,也可以为喜欢的文章点赞.下面我们一起分析一下 Halo 项目中评论和点赞功能的实现过程. 发表评论 评论可以 ...
- 使用Docker快速搭建Halo个人博客到阿里云服务器上[附加主题和使用域名访问]
一.前言 小编买了一个服务器也是一直想整个网站,一直在摸索,看了能够快速搭建博客系统的教程.总结了有以下几种方式,大家按照自己喜欢的去搭建: halo wordpress hexo vuepress ...
- 《Django By Example》第五章 中文 翻译 (个人学习,渣翻)
书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag注:大家好,我是新来的翻译, ...
- 旺财速啃H5框架之Bootstrap(五)
在上一篇<<旺财速啃H5框架之Bootstrap(四)>>做了基本的框架,<<旺财速啃H5框架之Bootstrap(二)>>篇里也大体认识了bootst ...
- 移动站应该尝试百度MIP的五个原因
MIP是什么?MIP是百度在2016年提出的移动网页加速器项目. MIP能做什么?MIP能帮助站长和网站开发者快速搭建移动端页面. MIP怎么加速?MIP从前端渲染和页面网络传输两方面进行优化,杜绝页 ...
- 如何一步一步用DDD设计一个电商网站(五)—— 停下脚步,重新出发
阅读目录 前言 单元测试 纠正错误,重新出发 结语 一.前言 实际编码已经写了2篇了,在这过程中非常感谢有听到观点不同的声音,借着这个契机,今天这篇就把大家提出的建议一个个的过一遍,重新整理,重新出发 ...
- MVVM模式解析和在WPF中的实现(五)View和ViewModel的通信
MVVM模式解析和在WPF中的实现(五) View和ViewModel的通信 系列目录: MVVM模式解析和在WPF中的实现(一)MVVM模式简介 MVVM模式解析和在WPF中的实现(二)数据绑定 M ...
- 【原】AFNetworking源码阅读(五)
[原]AFNetworking源码阅读(五) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 上一篇中提及到了Multipart Request的构建方法- [AFHTTP ...
- JavaScript常见的五种数组去重的方式
▓▓▓▓▓▓ 大致介绍 JavaScript的数组去重问题在许多面试中都会遇到,现在做个总结 先来建立一个数组 var arr = [1,2,3,3,2,'我','我',34,'我的',NaN,NaN ...
随机推荐
- [Java复习] 微服务
1. 怎么样定义一个微服务,或划分服务比较合理?业务导向的共性? 对应服务拆分,先设计高内聚低耦合的领域模型(DD),再实现相应的分布式系统是一种比较合理的方式. 微服务是手段,不是目的.目的是为了让 ...
- [转]Windows 10 无法访问共享的解决办法大全
本文前面介绍 Windows 10 操作系统无法访问其他电脑的共享文件夹,而其他电脑访问该共享可以访问的解决办法. 简单点说就是,你的操作系统是 Win10 ,你访问不了某台电脑的共享,但是别人可以. ...
- Java基本数据类型及所占字节大小
一.Java基本数据类型 基本数据类型有8种:byte.short.int.long.float.double.boolean.char 分为4类:整数型.浮点型.布尔型.字符型. 整数型:byte. ...
- 别人的双11 & 程序员的双11~
双11,致敬所有的程序员欧巴! 愿代码的世界,只有爱,没有伤害!! 点此参加阿里云双十一拼团活动:https://m.aliyun.com/act/team1111/ 阅读原文
- fiddler使用笔记1
转载地址:写得很不错的fildder教程 http://kb.cnblogs.com/page/130367/ Fiddler的基本介绍 Fiddler的官方网站: www.fiddler2.c ...
- webpack 4.+版本需要注意的地方
在webpack打包的时候需要npm下载webpack-cli,而且打包JS的命令从以前的webpack .\src\main.js .\dist\boundle.js 要编程 webpack .\ ...
- UE编辑器
引用ue的js 下载地址http://pan.baidu.com/s/1gdrQ35L <script type="text/javascript" src="__ ...
- frida的js脚本处理正则的一个小坑
frida的server模式需要python支持,所以js脚本中的正则需要多一次转义 比如匹配"/proc/{数字pid}" server: paramPath.match(&qu ...
- IDEA 创建 Maven web项目注意事项
需要设置 Maven ->Runner->VM options -Dmaven.multiModuleProjectDirectory=$M2_HOME 需要添加一个archetypeCa ...
- docker安装部署命令
一.安装工具包 $ sudo yum install -y yum-utils #安装工具包,缺少这些依赖将无法完成 二.设置远程仓库 $sudo yum-config-manager --add-r ...