0

0

如何在 Java 中安全删除文件与目录(排除指定 Glob 模式匹配项)

花韻仙語

花韻仙語

发布时间:2026-02-27 12:19:01

|

322人浏览过

|

来源于php中文网

原创

如何在 Java 中安全删除文件与目录(排除指定 Glob 模式匹配项)

本文介绍使用 Java NIO.2 的 PathMatcher 和 Files API,精准删除指定路径集合中的文件/目录,同时安全跳过符合 glob 模式(如 *.txt)的项,避免误删,兼顾健壮性与可读性。

本文介绍使用 java nio.2 的 `pathmatcher` 和 `files` api,精准删除指定路径集合中的文件/目录,同时安全跳过符合 glob 模式(如 `*.txt`)的项,避免误删,兼顾健壮性与可读性。

在实际项目清理逻辑中(如构建后清理、缓存回收或测试资源重置),常需批量删除一组路径,但必须保留特定模式的文件或目录——例如保留所有 .txt 日志、.properties 配置或 build/ 目录。此时,简单遍历 + FileUtils.deleteQuietly() 无法原生支持“条件排除”,易导致关键资源被误删。

Java 7 引入的 NIO.2 提供了强大且平台无关的路径匹配能力。核心在于 FileSystem.getPathMatcher(String),它支持 glob: 方案(如 glob:**/*.txt),可精确描述通配规则,并与 Path 对象高效比对。

以下为完整、生产就绪的实现方案:

✅ 推荐实现(基于 NIO.2,线程安全、异常可控)

import java.io.IOException;
import java.nio.file.*;
import java.nio.file.attribute.BasicFileAttributes;
import java.util.Set;

public class SafeCleaner {

    /**
     * 删除 cleanablePaths 中所有项,但跳过匹配 excludeGlobPattern 的路径
     * @param cleanablePaths 待清理的文件/目录路径集合(绝对路径)
     * @param excludeGlobPattern Glob 模式,如 "glob:**/*.txt" 或 "glob:config/**"
     */
    public static void deleteExcept(Set<Path> cleanablePaths, String excludeGlobPattern) {
        // 创建 PathMatcher(注意:glob 模式必须以 "glob:" 开头)
        PathMatcher matcher = FileSystems.getDefault().getPathMatcher(excludeGlobPattern);

        for (Path path : cleanablePaths) {
            try {
                // 标准化路径并检查是否匹配排除模式(区分大小写,按系统默认规则)
                Path normalized = path.toRealPath(LinkOption.NOFOLLOW_LINKS);
                if (matcher.matches(normalized)) {
                    System.out.println("SKIP (excluded by pattern): " + normalized);
                    continue;
                }

                // 安全删除:文件直接删;目录递归删(含子项)
                if (Files.isDirectory(path)) {
                    Files.walkFileTree(path, new SimpleFileVisitor<Path>() {
                        @Override
                        public FileVisitResult visitFile(Path file, BasicFileAttributes attrs)
                                throws IOException {
                            Files.delete(file);
                            return FileVisitResult.CONTINUE;
                        }

                        @Override
                        public FileVisitResult postVisitDirectory(Path dir, IOException exc)
                                throws IOException {
                            if (exc == null) {
                                Files.delete(dir);
                                return FileVisitResult.CONTINUE;
                            } else {
                                throw exc;
                            }
                        }
                    });
                } else {
                    Files.deleteIfExists(path);
                }
                System.out.println("DELETED: " + path);

            } catch (IOException e) {
                System.err.println("Failed to delete " + path + ": " + e.getMessage());
            }
        }
    }
}

? 关键说明与最佳实践

  • Glob 模式语法:必须显式添加 glob: 前缀。常见写法:

    立即学习Java免费学习笔记(深入)”;

    Spell.tools
    Spell.tools

    高颜值AI内容营销创作工具

    下载
    • glob:*.txt → 当前目录下所有 .txt 文件
    • glob:**/*.log → 所有子目录中的 .log 文件(递归)
    • glob:build/** → 整个 build/ 目录及其全部内容(但本例中会跳过该目录)
    • glob:config?/app.properties → 匹配 config1/app.properties、configA/app.properties 等
  • 路径标准化很重要:调用 toRealPath(LinkOption.NOFOLLOW_LINKS) 可消除符号链接、..、. 等歧义,确保匹配逻辑可靠;若需保留符号链接行为,可改用 normalize(),但需自行处理循环引用风险。

  • 不依赖 Apache Commons IO:本方案纯 JDK 实现(Java 7+),无第三方依赖,减少类路径污染与版本冲突。

  • 异常处理更精细:相比 deleteQuietly() 的静默失败,此处捕获 IOException 并打印错误,便于调试;你也可根据需要抛出自定义异常或记录到 SLF4J。

  • 性能提示:若 cleanablePaths 极大(>10k),建议结合 ForkJoinPool 并行处理,但需注意文件系统 I/O 并发瓶颈;一般场景下顺序执行已足够高效。

⚠️ 注意事项

  • PathMatcher 默认区分大小写(Windows 下通常不敏感,Linux/macOS 敏感)。如需跨平台一致的不区分大小写匹配,请改用正则模式:regex:(?i).*\.txt$(需将 glob: 替换为 regex:)。
  • 切勿在 excludeGlobPattern 中使用危险通配符如 glob:**(无限制递归),应始终限定作用域(如 glob:target/**)。
  • 生产环境建议在执行前增加 dry-run 模式(仅打印将删除/跳过的路径),验证逻辑正确性。

通过以上方式,你不仅能安全、清晰地表达“删除除某模式外的所有项”这一业务意图,还能获得更好的可维护性与跨平台兼容性。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

870

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

870

2023.08.02

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

721

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1313

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1156

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

825

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

460

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2361

2023.08.08

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

2

2026.02.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 10.3万人学习

Java 教程
Java 教程

共578课时 | 73.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号