Как экспортировать/импортировать список сеансов PuTTy?

Есть ли способ сделать это?

Или мне нужно вручную записывать каждую запись из реестра?

Ответ 1

Экспорт

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

Powershell:

Только сеансы:

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

PowerShell:

reg import putty-sessions.reg
reg import putty.reg

Примечание. не заменяйте SimonTatham своим именем пользователя.

Примечание. Он создаст файл reg на рабочем столе текущего пользователя.

Примечание. Он будет не экспортировать связанные SSH-ключи.

Ответ 2

Когда я попробовал другие решения, я получил эту ошибку:

Registry editing has been disabled by your administrator.

Прошу прощения, я говорю!

Я собрал приведенные ниже сценарии powershell для экспорта и импорта настроек PuTTY. Экспортированный файл является файлом .reg и Windows. Он будет автоматически импортироваться, если у вас есть разрешение, иначе используйте import.ps1 для его загрузки.

Предупреждение: возиться с реестром, как будто это Bad Idea ™, и я не знаю, что я делаю. Используйте приведенные ниже сценарии на свой страх и риск и будьте готовы к тому, чтобы ваш ИТ-отдел повторно просмотрел вашу машину и задал вам неудобные вопросы о том, что вы делаете.

На исходном компьютере:

.\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. Усовершенствования приветствуются!

Ответ 3

  • Запуск запуска, затем введите раскрывающееся окно Open: regedit

  • Перейдите к, как в проводнике окон:
    HKEY_CURRENT_USER\Software\SimonTatham

  • Щелкните правой кнопкой мыши по значку "SimonTatham" (значок каталога), выберите "Экспорт" Дайте файлу имя (скажем) putty.reg и сохраните его в своем местоположении для
    позже использование.
  • Закрыть редактор реестра.

Готово.

Ответ 4

Если вы хотите импортировать настройки в PuTTY Portable, вы можете использовать файл putty.reg.

Просто поставьте его на этот путь [path_to_Your_portable_apps]PuTTYPortable\Data\settings\putty.reg. Программа импортирует его

Ответ 5

Для тех из вас, кто должен импортировать 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 все было там. Простой и эффективный.

Ответ 6

Это было намного проще импортировать экспорт реестра, чем указано выше. + Просто:

  • щелкните правой кнопкой мыши файл и
  • выберите "Объединить"

Работал как чемпион на Win 7 Pro.

Ответ 7

Для тех, кто не хочет связываться с реестром, была создана вариация замазки, которая сохраняет файл. Он расположен здесь: http://jakub.kotrla.net/putty/

Было бы неплохо, если бы команда шпатлевки принимала это как опцию в основной дистрибутив.

Ответ 8

Улучшение решения bumerang для импорта данных в 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"

Ответ 9

Пример:
Как передать конфигурацию штейна и конфигурацию сеанса из одной учетной записи пользователя в другую, например. при создании новой учетной записи и хотите использовать сеансы/конфигурации шпатлевки из старой учетной записи

Процесс:
 - Экспорт ключа реестра из старой учетной записи в файл
 - Импортировать ключ реестра из файла в новую учетную запись

Экспорт ключа reg: (из учетной записи OLD)

  • Войдите в учетную запись OLD, например. tomold
  • Откройте обычную командную строку (НЕ admin!)
  • Введите 'regedit'
  • Перейдите в раздел реестра, в котором хранится конфигурация, например. [HKEY_CURRENT_USER\SOFTWARE\SimonTatham] и нажмите на него.
  • Выберите "Экспорт" из меню файла или щелкните правой кнопкой мыши (радиокадр "выбранная ветвь" )
  • Сохраните файл и назовите его, например. 'Puttyconfig.reg'
  • Выход снова

Импортировать ключ reg: (в учетную запись NEW)

  1. Войдите в новую учетную запись, например. Том

  2. Откройте обычную "командную строку" (НЕ admin!)

  3. Введите 'regedit'

  4. Выберите "Импорт" в меню

  5. Выберите файл реестра для импорта, например. 'Puttyconfig.reg'

  6. Готово

Примечание:
Не используйте "командную строку администратора", поскольку параметры находятся в разделе "[HKEY_CURRENT_USER...]", а regedit будет запускаться как администратор и показывать этот раздел для пользователя-администратора, а не для передачи пользователем и/или.

Ответ 10

Ответ, отправленный @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

Ответ 11

Ответ на

m0nhawk не работал у меня в Windows 10 - для этого требовалась повышенная командная строка и отказался выдавать файл.

Это сработало и не требовало повышения:

reg export HKEY_CURRENT_USER\Software\SimonTatham\PuTTY putty.reg

Ответ 12

Используя этот метод, можно также выполнить массовые изменения конфигурации, такие как изменение шрифта всех сеансов.

  • Экспорт в .reg
  • Выполните поиск и замените на .reg
  • Удалить все сеансы
  • Импортировать новый .reg

Извлечен здесь: http://www.sysadmit.com/2015/11/putty-exportar-configuracion.html

Ответ 14

Существует сценарий PowerShell на ratil.life/first-useful-powershell-script-putty-to-ssh-config, который может преобразовывать сеансы в формат, который можно использовать в .ssh/config. Его также можно найти на GitHub.

Эта выдержка содержит основные кишки кода и будет печатать полученную конфигурацию непосредственно в stdout:

# 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 }
    }

}

Ответ 15

Если вы, как и я, установили новую Windows и только после того, как вспомнили о сеансах замазки, вы все равно можете импортировать их, если у вас есть старый жесткий диск Windows или, по крайней мере, ваш старый "домашний" каталог скопирован (C:\Users\<user_name>).

В этом каталоге должен быть файл NTUSER.DAT. По умолчанию он скрыт, поэтому вы должны включить скрытые файлы в проводнике Windows или использовать другой файловый браузер. Этот файл содержит ветку HKEY_CURRENT_USER вашего старого реестра Windows.

Чтобы использовать его, вам нужно открыть regedit в новой Windows и нажать клавишу HKEY_USERS.

Затем выберите FileLoad 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 в редакторе реестра, затем выберите FileUnload Hive... и подтвердите эту операцию.