Есть ли способ сделать это?
Или я должен вручную взять каждую запись из реестра?
Есть ли способ сделать это?
Или я должен вручную взять каждую запись из реестра?
Ответы:
cmd.exe
, Требует повышенной строки:Только сеансы:
regedit /e "%USERPROFILE%\Desktop\putty-sessions.reg" HKEY_CURRENT_USER\Software\SimonTatham\PuTTY\Sessions
Все настройки:
regedit /e "%USERPROFILE%\Desktop\putty.reg" HKEY_CURRENT_USER\Software\SimonTatham
Только сеансы:
reg export HKCU\Software\SimonTatham\PuTTY\Sessions ([Environment]::GetFolderPath("Desktop") + "\putty-sessions.reg")
Все настройки:
reg export HKCU\Software\SimonTatham ([Environment]::GetFolderPath("Desktop") + "\putty.reg")
Дважды щелкните *.reg
файл и примите импорт.
cmd.exe
, требуется повышенная командная строка:regedit /i putty-sessions.reg
regedit /i putty.reg
reg import putty-sessions.reg
reg import putty.reg
Примечание : не заменяйте SimonTatham
своим именем пользователя.
Примечание . Он создаст reg
файл на рабочем столе текущего пользователя.
Примечание : он не будет экспортировать связанные ключи SSH.
Когда я попробовал другие решения, я получил эту ошибку:
Registry editing has been disabled by your administrator.
Фу на это, говорю я!
Я собрал приведенные ниже скрипты powershell для экспорта и импорта настроек PuTTY. Экспортированный файл - это файл Windows .reg, и он будет импортироваться без ошибок, в противном случае используйте import.ps1 для его загрузки.
Предупреждение : возиться с реестром, как это плохая идея ™, и я действительно не знаю, что я делаю. Используйте сценарии, представленные ниже, на свой страх и риск, и будьте готовы к тому, что ваш ИТ-отдел заново создаст образ вашей машины и задаст вам неудобные вопросы о том, что вы делали.
На исходном компьютере:
.\export.ps1
На целевой машине:
.\import.ps1 > cmd.ps1
# Examine cmd.ps1 to ensure it doesn't do anything nasty
.\cmd.ps1
export.ps1
# All settings
$registry_path = "HKCU:\Software\SimonTatham"
# Only sessions
#$registry_path = "HKCU:\Software\SimonTatham\PuTTY\Sessions"
$output_file = "putty.reg"
$registry = ls "$registry_path" -Recurse
"Windows Registry Editor Version 5.00" | Out-File putty.reg
"" | Out-File putty.reg -Append
foreach ($reg in $registry) {
"[$reg]" | Out-File putty.reg -Append
foreach ($prop in $reg.property) {
$propval = $reg.GetValue($prop)
if ("".GetType().Equals($propval.GetType())) {
'"' + "$prop" + '"' + "=" + '"' + "$propval" + '"' | Out-File putty.reg -Append
} elseif ($propval -is [int]) {
$hex = "{0:x8}" -f $propval
'"' + "$prop" + '"' + "=dword:" + $hex | Out-File putty.reg -Append
}
}
"" | Out-File putty.reg -Append
}
import.ps1
$input_file = "putty.reg"
$content = Get-Content "$input_file"
"Push-Location"
"cd HKCU:\"
foreach ($line in $content) {
If ($line.StartsWith("Windows Registry Editor")) {
# Ignore the header
} ElseIf ($line.startswith("[")) {
$section = $line.Trim().Trim('[', ']')
'New-Item -Path "' + $section + '" -Force' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
} ElseIf ($line.startswith('"')) {
$linesplit = $line.split('=', 2)
$key = $linesplit[0].Trim('"')
if ($linesplit[1].StartsWith('"')) {
$value = $linesplit[1].Trim().Trim('"')
} ElseIf ($linesplit[1].StartsWith('dword:')) {
$value = [Int32]('0x' + $linesplit[1].Trim().Split(':', 2)[1])
'New-ItemProperty "' + $section + '" "' + $key + '" -PropertyType dword -Force' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
} Else {
Write-Host "Error: unknown property type: $linesplit[1]"
exit
}
'Set-ItemProperty -Path "' + $section + '" -Name "' + $key + '" -Value "' + $value + '"' | %{ $_ -replace 'HKEY_CURRENT_USER\\', '' }
}
}
"Pop-Location"
Извиняюсь за неидиоматический код, я не очень знаком с Powershell. Улучшения приветствуются!
Запустите Run, затем введите в раскрывающемся окне Открыть: regedit
Перейдите к, как в Проводнике Windows:
HKEY_CURRENT_USER \ Software \ SimonTatham
Выполнено.
Для тех из вас, кому необходимо импортировать Putty из автономного файла реестра, например, когда вы восстанавливаетесь после сбоя системы или просто переходите на новый компьютер и извлекаете данные со старого диска, есть еще одно решение, которое стоит упомянуть:
http://www.nirsoft.net/utils/registry_file_offline_export.html
Это отличное и бесплатное консольное приложение будет экспортировать весь реестр или только определенный раздел реестра. В моем случае я просто скопировал файл реестра со старого диска в тот же каталог, что и средство экспорта, а затем использовал следующую команду и синтаксис в окне CMD, запущенном от имени администратора:
RegFileExport.exe NTUSER.DAT putty.reg "HKEY_CURRENT_USER \ Software \ SimonTatham"
После импорта файла .reg и запуска Putty все было там. Просто и эффективно.
Для тех, кто не хочет связываться с реестром, была создана разновидность шпаклевки, которая сохраняется в файл. Он находится здесь: http://jakub.kotrla.net/putty/
Было бы неплохо, если бы команда разработчиков putty приняла это в качестве опции в основной дистрибутив.
Это было гораздо проще импортировать из реестра, чем указано выше. + Просто:
Работал как чемпион на Win 7 Pro.
Пример:
Как перенести конфигурацию замазки и конфигурацию сеанса из одной учетной записи пользователя в другую, например, когда создается новая учетная запись и вы хотите использовать сеансы / конфигурации замазки из старой учетной записи
Процесс:
- экспорт ключа реестра из старой учетной записи в файл
- импорт ключа реестра из файла в новую учетную запись
Экспорт регистрационного ключа: (со СТАРОГО аккаунта)
Импортировать регистрационный ключ: (в НОВЫЙ аккаунт)
Войти в новый аккаунт, например, Том
Откройте обычную командную строку (НЕ администратор!)
Тип "regedit"
Выберите «Импорт» из меню
Выберите файл реестра для импорта, например, 'puttyconfig.reg'
Выполнено
Примечание:
не используйте «командную строку администратора», так как настройки находятся в «[HKEY_CURRENT_USER ...]», и regedit будет запускаться от имени администратора и показывать этот раздел для пользователя-администратора, а не для пользователя, из которого будет выполняться переход и / или к.
Улучшение решения бумеранга для импорта данных в PuTTY portable
.
Простое перемещение экспортированного putty.reg
(с решением m0nhawk) в PuTTYPortable\Data\settings\
не работало. PuTTY Portable создайте резервную копию файла и создайте новый пустой.
Чтобы обойти эту проблему, объедините обе putty.reg
копии, скопировав вручную конфигурацию, которую вы хотите перенести из вашей экспортированной, putty.reg
во вновь созданные PuTTYPortable\Data\settings\putty.reg
ниже следующие строки.
REGEDIT4
[HKEY_CURRENT_USER\Software\SimonTatham\PuTTY]
"RandSeedFile"="D:\\Programme\\PuTTYPortable\\Data\\settings\\PUTTY.RND"
Ответ, отправленный @ m0nhawk, похоже, не работает, когда я тестирую на компьютере с Windows 7. Вместо этого, используя следующие скрипты, вы сможете экспортировать / импортировать настройки putty:
::export
@echo off
set regfile=putty.reg
pushd %~dp0
reg export HKCU\Software\SimonTatham %regfile% /y
popd
-
::import
@echo off
pushd %~dp0
set regfile=putty.reg
if exist %regfile% reg import %regfile%
popd
Используя этот метод, также можно выполнять массовые изменения конфигурации, такие как изменение шрифта всех сеансов.
Извлечено отсюда: http://www.sysadmit.com/2015/11/putty-exportar-configuracion.html
Я использую менеджер соединений putty, где вы создаете базу данных сессий. Эту базу данных легко скопировать и импортировать на другие компьютеры.
Смотрите это удобное руководство
Существует сценарий PowerShell по адресу ratil.life/first-useful-powershell-script-putty-to-ssh-config, который может преобразовывать сеансы в формат, который можно использовать в .ssh/config
. Его также можно найти на GitHub .
Этот отрывок содержит основные элементы кода и распечатывает полученную конфигурацию непосредственно на стандартный вывод:
# Registry path to PuTTY configured profiles
$regPath = 'HKCU:\SOFTWARE\SimonTatham\PuTTY\Sessions'
# Iterate over each PuTTY profile
Get-ChildItem $regPath -Name | ForEach-Object {
# Check if SSH config
if (((Get-ItemProperty -Path "$regPath\$_").Protocol) -eq 'ssh') {
# Write the Host for easy SSH use
$host_nospace = $_.replace('%20', $SpaceChar)
$hostLine = "Host $host_nospace"
# Parse Hostname for special use cases (Bastion) to create SSH hostname
$puttyHostname = (Get-ItemProperty -Path "$regPath\$_").HostName
if ($puttyHostname -like '*@*') {
$sshHostname = $puttyHostname.split("@")[-1]
}
else { $sshHostname = $puttyHostname }
$hostnameLine = "`tHostName $sshHostname"
# Parse Hostname for special cases (Bastion) to create User
if ($puttyHostname -like '*@*') {
$sshUser = $puttyHostname.split("@")[0..($puttyHostname.split('@').length - 2)] -join '@'
}
else { $sshHostname = $puttyHostname }
$userLine = "`tUser $sshUser"
# Parse for Identity File
$puttyKeyfile = (Get-ItemProperty -Path "$regPath\$_").PublicKeyFile
if ($puttyKeyfile) {
$sshKeyfile = $puttyKeyfile.replace('\', '/')
if ($prefix) { $sshKeyfile = $sshKeyfile.replace('C:', $prefix) }
$identityLine = "`tIdentityFile $sshKeyfile"
}
# Parse Configured Tunnels
$puttyTunnels = (Get-ItemProperty -Path "$regPath\$_").PortForwardings
if ($puttyTunnels) {
$puttyTunnels.split() | ForEach-Object {
# First character denotes tunnel type
$tunnelType = $_.Substring(0,1)
# Digits follow tunnel type is local port
$tunnelPort = $_ -match '\d*\d(?==)' | Foreach {$Matches[0]}
# Text after '=' is the tunnel destination
$tunnelDest = $_.split('=')[1]
if ($tunnelType -eq 'D') {
$tunnelLine = "`tDynamicForward $tunnelPort $tunnelDest"
}
ElseIf ($tunnelType -eq 'R') {
$tunnelLine = "`tRemoteForward $tunnelPort $tunnelDest"
}
ElseIf ($tunnelType -eq 'L') {
$tunnelLine = "`tLocalForward $tunnelPort $tunnelDest"
}
}
# Parse if Forward Agent is required
$puttyAgent = (Get-ItemProperty -Path "$regPath\$_").AgentFwd
if ($puttyAgent -eq 1) { $agentLine = "`tForwardAgent yes" }
# Parse if non-default port
$puttyPort = (Get-ItemProperty -Path "$regPath\$_").PortNumber
if (-Not $puttyPort -eq 22) { $PortLine = "`tPort $puttyPort" }
}
# Build output string
$output = "$hostLine`n$hostnameLine`n$userLine`n$identityLine`n$tunnelLine`n$agentLine`n"
# Output to file if set, otherwise STDOUT
if ($outfile) { $output | Out-File $outfile -Append}
else { Write-Host $output }
}
}
Если вы, как и я, установили новую Windows и только после того, как вспомнили о сеансах замазки, вы все равно можете их импортировать, если у вас есть старый жесткий диск Windows или, по крайней мере, ваш старый «домашний» каталог был заархивирован ( C:\Users\<user_name>
).
В этом каталоге должен быть NTUSER.DAT
файл. По умолчанию он скрыт, поэтому вы должны включить скрытые файлы в проводнике Windows или использовать другой файловый браузер. Этот файл содержит HKEY_CURRENT_USER
ветку вашего старого реестра Windows.
Чтобы использовать его, вам нужно открыть regedit
на новой Windows, и выберите HKEY_USERS
ключ.
Затем выберите File
-> Load Hive...
и найдите ваш старый «домашний» каталог вашей старой установки Windows. В этом каталоге должен быть NTUSER.DAT
файл. По умолчанию он скрыт, поэтому, если вы не включили отображение скрытых файлов в свойствах проводника Windows, вы можете просто вручную ввести имя файла в File name
поле ввода диалога «Загрузить куст» и нажать Enter. Затем в следующем диалоговом окне введите имя ключа, чтобы загрузить в него старый реестр. например tmp
.
HKEY_CURRENT_USER
Ветвь вашего старого реестра теперь должна быть доступна под HKEY_USERS\tmp
веткой вашего текущего реестра.
Теперь экспортируйте HKEY_USERS\tmp\Software\SimonTatham
ветку в putty.reg
файл, откройте этот файл в вашем любимом текстовом редакторе и найдите и замените всю HKEY_USERS\tmp
строку на HKEY_CURRENT_USER
. Теперь сохраните .reg
файл.
Теперь вы можете импортировать этот файл в текущий реестр Windows, дважды щелкнув по нему. Смотрите ответ m0nhawk, как это сделать.
В конце выберите HKEY_USERS\tmp
ветку в редакторе реестра, затем выберите File
-> Unload Hive...
и подтвердите эту операцию.