Создание жестких и полезных ссылок с помощью PowerShell
Может ли PowerShell 1.0 создавать жесткие и мягкие ссылки, аналогичные разнообразию Unix?
Если это не встроено, может ли кто-нибудь указать мне на сайт с ps1 script, который имитирует это?
Это необходимая функция любой хорошей оболочки, ИМХО.:)
Ответы
Ответ 1
Вы можете вызвать mklink
, предоставленный cmd
, из PowerShell для создания символических ссылок:
cmd /c mklink c:\path\to\symlink c:\target\file
Вы должны передать /d
mklink
, если целью является каталог.
cmd /c mklink /d c:\path\to\symlink c:\target\directory
Для жестких ссылок я предлагаю что-то вроде Sysinternals Junction.
Ответ 2
Windows 10 (и Powershell 5.0 в целом) позволяет создавать символические ссылки с помощью командлета New-Item.
Использование:
New-Item -Path C:\LinkDir -ItemType SymbolicLink -Value F:\RealDir
Или в вашем профиле:
function make-link ($target, $link) {
New-Item -Path $link -ItemType SymbolicLink -Value $target
}
Включите режим разработчика, чтобы не требовать прав администратора при создании ссылок с New-Item
:
![enter image description here]()
Ответ 3
Добавить модуль "pscx"
Нет, он не встроен в PowerShell. И утилита mklink
не может быть вызвана сама по себе в Windows Vista/Windows 7, потому что она встроена непосредственно в cmd.exe
как "внутренняя команда".
Вы можете использовать Расширения сообщества PowerShell (бесплатно). Существует несколько командлетов для точек повторного анализа различных типов:
New-HardLink
,
New-SymLink
,
New-Junction
,
Remove-ReparsePoint
- и другие.
Ответ 4
В Windows 7 команда
fsutil hardlink create new-file existing-file
PowerShell находит его без полного пути (c:\Windows\system32) или расширения (.exe).
Ответ 5
New-Symlink:
Function New-SymLink ($link, $target)
{
if (test-path -pathtype container $target)
{
$command = "cmd /c mklink /d"
}
else
{
$command = "cmd /c mklink"
}
invoke-expression "$command $link $target"
}
Remove-Symlink:
Function Remove-SymLink ($link)
{
if (test-path -pathtype container $link)
{
$command = "cmd /c rmdir"
}
else
{
$command = "cmd /c del"
}
invoke-expression "$command $link"
}
Использование:
New-Symlink "c:\foo\bar" "c:\foo\baz"
Remove-Symlink "c:\foo\bar"
Ответ 6
Попробуйте junction.exe
Утилита командной строки Junction от SysInternals упрощает создание и удаление соединений.
Дальнейшее чтение
- Терминология MS: мягкая! = Символическая
Microsoft использует "мягкую ссылку" в качестве другого названия для "соединения".
Однако "символическая ссылка" - это нечто совершенно другое.
См. MSDN: Жесткие ссылки и соединения в Windows.
(Это находится в прямом противоречии с общим использованием тех терминов, где "мягкая ссылка" и "символическая ссылка" ("символическая ссылка") действительно означают одно и то же.)
Ответ 7
Вы можете использовать эту утилиту:
c:\Windows\system32\fsutil.exe create hardlink
Ответ 8
Я написал модуль PowerShell, который имеет встроенные оболочки для MKLINK. https://gist.github.com/2891103
Включает функции для:
- New-Symlink
- New-HardLink
- New-Junction
Захват вывода MKLINK и, при необходимости, генерирует правильные ошибки PowerShell.
Ответ 9
Я объединил два ответа (@bviktor и @jocassid). Он был протестирован в Windows 10 и Windows Server 2012.
function New-SymLink ($link, $target)
{
if ($PSVersionTable.PSVersion.Major -ge 5)
{
New-Item -Path $link -ItemType SymbolicLink -Value $target
}
else
{
$command = "cmd /c mklink /d"
invoke-expression "$command ""$link"" ""$target"""
}
}
Ответ 10
Собственно, команда Sysinternals junction
работает только с каталогами (не спрашивайте меня почему), поэтому она не может жестко привязать файлы. Я бы пошел с cmd /c mklink
для мягких ссылок (я не могу понять, почему он не поддерживается напрямую PowerShell) или fsutil
для жестких ссылок.
Если вам это нужно для работы с Windows XP, я не знаю ничего, кроме Sysinternals junction
, поэтому вы можете ограничить каталоги.
Ответ 11
Я нашел это простым способом без внешней помощи. Да, он использует архаичную команду DOS, но она работает, это легко, и это понятно.
$target = cmd /c dir /a:l | ? { $_ -match "mySymLink \[.*\]$" } | % `
{
$_.Split([char[]] @( '[', ']' ), [StringSplitOptions]::RemoveEmptyEntries)[1]
}
Это использует команду dOS dir для поиска всех записей с атрибутом символической ссылки, фильтров по определенному имени ссылки, за которыми следуют целевые "[]" скобки, а для каждого - предположительно один - извлекает только целевую строку.