0

0

C#怎么判断路径是否合法_C#如何校验文件名中的非法字符【示例】

尼克

尼克

发布时间:2026-03-19 09:42:31

|

602人浏览过

|

来源于php中文网

原创

校验路径合法性需区分场景:完整路径用 Path.GetInvalidPathChars(),纯文件名用 Path.GetInvalidFileNameChars();须先用 Path.GetDirectoryName() 和 Path.GetFileName() 拆解再分别校验,且需额外检查保留名(如 CON)和路径结构有效性。

c#怎么判断路径是否合法_c#如何校验文件名中的非法字符【示例】

Path.GetInvalidPathChars()Path.GetInvalidFileNameChars() 区分校验场景

路径合法 ≠ 文件名合法。Windows 下,C: oo:bar 整体是非法路径(冒号不允许),但 foo:bar 单独作为文件名片段时,冒号也非法;而 在路径中是分隔符,在文件名里直接出现就崩溃。所以得拆开校验:Path.GetInvalidPathChars() 用于检查完整路径字符串是否含非法字符(如 :*?"、<code>>|),Path.GetInvalidFileNameChars() 更严格,额外排除 /.(末尾)、空格(开头/结尾)等——它只管“文件名部分”,不处理路径结构。

常见错误是拿 GetInvalidFileNameChars() 去校验整个 C: emp est.txt,结果一碰到 就误报非法。正确做法:先用 Path.GetDirectoryName()Path.GetFileName() 拆解,再分别校验。

  • 校验路径字符串(含盘符、目录)→ 用 Path.GetInvalidPathChars()
  • 校验纯文件名(不含路径)→ 用 Path.GetInvalidFileNameChars()
  • 注意:GetInvalidFileNameChars() 不检查保留名(如 CONAUX),需额外判断

手动遍历检查比 Path.IsPathRooted() 更可靠

Path.IsPathRooted() 只判断是否“看起来像根路径”(如以 C:\ 开头),完全不校验字符合法性。比如 C: oo<bar> 是根路径,但含非法字符 <code>,直接传给 <code>File.Create() 会抛 ArgumentException

真正安全的做法是:对路径字符串逐字符比对 Path.GetInvalidPathChars() 返回的数组。别依赖异常驱动——提前拦住比捕获 IOException 更可控。

  • 不要用 try/catch 包裹 File.Exists() 来“试探”路径是否合法
  • Path.IsPathRooted()Path.HasExtension() 都不校验字符,只是语法解析
  • 网络路径(\servershare)需额外检查 UNC 前缀是否规范,Path.GetInvalidPathChars() 已覆盖其中非法字符

保留名(CONPRN 等)必须单独处理

Windows 禁止使用 CONPRNAUXNUL 及带数字后缀的变体(如 CON1PRN99)作为文件名,哪怕字符全合法。这个规则 Path.GetInvalidFileNameChars() 完全不覆盖。

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载

判断逻辑很简单:取 Path.GetFileNameWithoutExtension() 的前 3 个字符(忽略大小写),看是否匹配保留名列表;还要注意扩展名不影响判定——CON.txtCON 一样非法。

  • 保留名匹配不区分大小写:conConCON 全部拦截
  • 仅检查主文件名部分,不包括路径和扩展名
  • 扩展名本身可以是 con(如 file.con 合法),但主名不能是保留名

实际校验函数建议这样写

把路径拆解、字符检查、保留名判断三步串起来,封装成一个函数比零散调用更稳妥:

public static bool IsValidFileName(string fileName)
{
    if (string.IsNullOrWhiteSpace(fileName)) return false;
    var nameOnly = Path.GetFileName(fileName);
    if (string.IsNullOrEmpty(nameOnly)) return false;

    // 检查非法字符
    if (nameOnly.IndexOfAny(Path.GetInvalidFileNameChars()) >= 0) return false;

    // 检查保留名(忽略扩展名)
    var baseName = Path.GetFileNameWithoutExtension(nameOnly);
    if (baseName.Length == 0) return false;
    var reserved = new[] { "CON", "PRN", "AUX", "NUL", "COM1", "COM2", "COM3", "COM4", "COM5", "COM6", "COM7", "COM8", "COM9", "LPT1", "LPT2", "LPT3", "LPT4", "LPT5", "LPT6", "LPT7", "LPT8", "LPT9" };
    if (reserved.Contains(baseName.ToUpperInvariant())) return false;

    return true;
}

注意:这个函数只校验“文件名部分”。如果要校验完整路径,还需额外用 Path.GetInvalidPathChars() 扫描整个字符串,并确保盘符存在、长度不超过 MAX_PATH(260 字符)——不过后者通常由系统 API 自动截断或报错,主动检查成本高,按需添加。

最易被忽略的是保留名和大小写无关性,以及 GetInvalidFileNameChars(). 的处理:它允许中间的点(如 file.name.txt),但禁止开头、结尾或连续多个点(.hidden 合法,..file. 非法)。这些边界情况不跑真实文件操作很难暴露。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c#是什么意思
c#是什么意思

C#是一种通用的面向对象编程语言,它在.NET框架上运行,可用于开发各种类型的应用程序。本专题为大家提供c#相关的各种文章、以及下载和课程。

279

2023.08.08

什么是c#
什么是c#

C#(读作C Sharp)是一种现代的、通用的、面向对象的编程语言。它由微软公司开发,于2000年首次发布,主要用于开发Windows桌面应用程序、Web应用程序、移动应用程序以及游戏开发等领域。C#是一种类型安全和托管的编程语言,它结合了C++的强大性能和C语言的简单易学特点,并引入了许多新的特性和概念,如委托、属性、泛型和异步编程等,以提高开发效率和代码可维护性。

185

2023.08.31

C#中base关键字的用法
C#中base关键字的用法

在C#中,base关键字用于访问当前类的基类成员,这包括基类的字段、属性、方法、构造函数、索引器以及事件。想了解更多C#的相关内容,可以阅读本专题下面的文章。

327

2024.03.13

C#Task用法
C#Task用法

Task在C#中是用于表示异步操作的对象,它位于System.Threading.Tasks命名空间中。想了解更多C#中各种用法的相关内容,可以阅读本专题下面的文章。

380

2024.03.14

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

29

2026.02.03

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

107

2026.02.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

416

2026.03.11

string转int
string转int

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

1091

2023.08.02

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

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

精品课程

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

共94课时 | 11.6万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.5万人学习

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

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