Есть ли способ сделать это?
Или мне нужно вручную брать каждую запись из реестра?
Есть ли способ сделать это?
Или мне нужно вручную брать каждую запись из реестра?
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.
.reg
файл со всеми настройками.
- person m0nhawk; 04.09.2016
HostName
.
- person m0nhawk; 17.05.2017
HKEY_CURRENT_USER\...
. Повышенные права требуются только для HKEY_LOCAL_MACHINE
, HKEY_CLASSES_ROOT
и т. Д.
- person Wernfried Domscheit; 16.11.2018
HKEY_LOCAL_MACHINE\SOFTWARE\SimonTatham\PuTTY64
.
- person WesternGun; 17.02.2019
Когда я попробовал другие решения, я получил эту ошибку:
Registry editing has been disabled by your administrator.
Я говорю!
Я собрал приведенные ниже сценарии PowerShell для экспорта и импорта настроек PuTTY. Экспортированный файл представляет собой файл .reg для Windows и будет импортирован без ошибок, если у вас есть разрешение, в противном случае используйте 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. Улучшения приветствуются!
Запустите «Выполнить», затем введите в раскрывающемся окне «Открыть»: regedit.
Перейдите к, как в проводнике Windows:
HKEY_CURRENT_USER \ Software \ SimonTatham
Выполнено.
Если вы хотите импортировать настройки в PuTTY Portable
, вы можете использовать файл putty.reg
.
Просто поместите его на этот путь [path_to_Your_portable_apps]PuTTYPortable\Data\settings\putty.reg
. Программа импортирует это
Для тех из вас, кому нужно импортировать 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 будет запускаться от имени администратора и показывать этот раздел пользователю с правами администратора. затем для перехода пользователя из и / или в.
Ответ m0nhawk не сработал для меня в Windows 10 - он требовал командной строки с повышенными правами и отказывался выдавать файл.
Это сработало и не потребовало повышения:
reg export HKEY_CURRENT_USER\Software\SimonTatham\PuTTY putty.reg
Улучшение решения бумеранга для импорта данных в 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. Вместо этого, используя следующие скрипты, можно будет экспортировать / импортировать настройки шпатлевки:
::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
Если вы, как и я, установили новую 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 kbd>. Затем в следующем диалоговом окне введите имя ключа, чтобы загрузить в него старый реестр. например 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...
и подтвердите эту операцию.
Сценарий 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 }
}
}
Я использую диспетчер соединений шпатлевки, в котором вы создаете базу данных сеансов. Эту базу данных легко скопировать и импортировать на другие компьютеры.
См. Это удобное руководство