0

0

C#创建符号链接 C#如何创建Symbolic Link链接文件或目录

月夜之吻

月夜之吻

发布时间:2026-02-14 09:33:10

|

753人浏览过

|

来源于php中文网

原创

windows下createsymboliclink需管理员权限,.net core 5+提供跨平台createsymboliclink方法,旧版可用mklink命令替代;符号链接默认被api自动解析,需用file.getattributes检查reparsepoint标志。

c#创建符号链接 c#如何创建symbolic link链接文件或目录

Windows平台下用 CreateSymbolicLink 创建链接需管理员权限

在C#中调用Windows原生API创建符号链接,核心是 CreateSymbolicLink 函数,它属于 kernel32.dll。这个函数本身不区分文件或目录链接,靠最后一个参数 dwFlags 控制:0 表示文件链接,1(即 SYMBOLIC_LINK_FLAG_DIRECTORY)表示目录链接。但关键前提是:**当前进程必须拥有“创建符号链接”权限**——默认只有管理员组成员或显式授予过该权限的用户才能成功。普通用户即使UAC关闭,调用也会返回错误码5(拒绝访问)。

实操建议:

  • 开发阶段先以管理员身份运行Visual Studio或命令行,避免反复排查权限问题
  • 生产环境若不能提权,改用硬链接(CreateHardLink)或目录交接点(junction),但二者语义不同:硬链接仅限同一卷内文件,交接点只支持目录且是NTFS特有
  • 调用前务必用 File.ExistsDirectory.Exists 确认目标路径存在,否则链接会创建成功但指向无效路径,访问时才报错

FileSystemInfo.CreateSymbolicLink 是.NET Core 5+ 的跨平台封装

.NET Core 5起,FileSystemInfo 类型新增了 CreateSymbolicLink 实例方法,底层在Windows上调用 CreateSymbolicLink,在Linux/macOS上使用 symlink 系统调用。它自动识别调用者是 FileInfo 还是 DirectoryInfo,省去手动判别 dwFlags 的麻烦。

注意点:

  • 该方法在 .NET Framework 中不可用,仅限 .NET Core 5 / .NET 5+ 和 .NET Standard 2.1+
  • Linux/macOS 上无需特殊权限,但目标路径父目录需有写权限;Windows 上仍受前述管理员权限限制
  • 如果目标已存在,方法会抛出 IOException(错误信息含“already exists”),需自行处理覆盖逻辑(先 Delete 再创建)

示例代码片段:

Brancher AI
Brancher AI

无代码连接AI模型,快速创建AI应用程序

下载
var target = new FileInfo(@"C:\real\file.txt");
var link = new FileInfo(@"C:\link\to-file.txt");
link.CreateSymbolicLink(target.FullName); // 自动按 FileInfo 类型创建文件链接

Process.Start 调用 mklink 是最兼容的备选方案

当项目受限于旧版.NET Framework(如4.8)或无法提权时,可绕过P/Invoke,直接启动系统命令 mklink。它对权限要求略低(部分场景标准用户也能执行),且语法直观。

关键细节:

  • /D 参数用于目录链接,无参数或 /J(交接点)用于目录,/H 用于硬链接——符号链接默认不加参数,但必须加 /D 才能建目录链接,否则报错“参数格式不正确”
  • 命令必须在CMD环境下执行,且链接路径和目标路径都推荐使用绝对路径,避免工作目录影响
  • 捕获 Process.StandardError 才能拿到真实错误(比如“系统不支持符号链接”通常意味着未启用开发者模式或非NTFS卷)

示例调用:

var psi = new ProcessStartInfo("cmd", $@"/c mklink ""{linkPath}"" ""{targetPath}""")
{
    UseShellExecute = false,
    RedirectStandardError = true,
    CreateNoWindow = true
};
using var p = Process.Start(psi);
p.WaitForExit();
if (p.ExitCode != 0)
    Console.WriteLine(p.StandardError.ReadToEnd()); // 查看具体失败原因

符号链接在.NET中的路径解析行为容易被忽略

创建成功后,File.ExistsDirectory.GetDirectories 等API默认会**自动跟随符号链接**,读取的是目标位置的内容。这和Linux中 ls -l 显示链接本身不同。若需区分链接与真实路径,必须用 File.GetAttributes 检查是否含 ReparsePoint 标志。

常见误判场景:

  • new FileInfo(linkPath).Length 得到的是目标文件大小,不是链接文件自身(它实际是0字节的元数据)
  • 递归遍历目录时,符号链接可能导致无限循环(如链接指向父目录),需记录已访问的 File.GetAttributes 结果并跳过 ReparsePoint
  • 在Docker for Windows或WSL2中挂载的路径里创建符号链接,宿主机和容器内解析行为可能不一致,优先测试实际运行环境

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

941

2023.09.19

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

287

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.12.29

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

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

1089

2023.07.26

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

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

1148

2023.07.27

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

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

818

2023.08.01

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

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

460

2023.08.02

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

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

2360

2023.08.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

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

精品课程

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

共94课时 | 9.4万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.6万人学习

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

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