如何导出/导入油灰会话列表



有没有办法做到这一点?

否则我必须手动从注册表中手动进行每张记录?

导出

cmd.exe需要升高的提示:

只有会话(在桌面上产生文件putty-sessions.reg):

regedit /e "%USERPROFILE%Desktopputty-sessions.reg" HKEY_CURRENT_USERSoftwareSimonTathamPuTTYSessions

除了ssh键以外的所有设置(在桌面上生成文件putty.reg):

regedit /e "%USERPROFILE%Desktopputty.reg" HKEY_CURRENT_USERSoftwareSimonTatham

PowerShell:

只有会话(在桌面上生成文件putty-sessions.reg):

reg export HKCUSoftwareSimonTathamPuTTYSessions ([Environment]::GetFolderPath("Desktop") + "putty-sessions.reg")

除了ssh键以外的所有设置(在桌面上生产文件putty.reg):

reg export HKCUSoftwareSimonTatham ([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

note :这些命令将不是导出相关的ssh键。

  1. 启动运行,然后在打开的下拉窗口中键入regedit
  2. 导航到HKEY_CURRENT_USERSoftwareSimonTatham
  3. 右键单击" Simontatham"键(目录图标),选择导出。给文件一个名称(例如)putty.reg,然后将其保存到您的位置以备后用。
  4. 关闭注册表编辑。

完成。

当我尝试其他解决方案时,我得到了此错误:

Registry editing has been disabled by your administrator.

phooey,我说!

我整理了以下PowerShell脚本,用于导出和导入油灰设置。导出的文件是一个Windows .REG文件,如果您有许可,将干净导入,否则请使用import.ps1加载它。

警告:与这样的注册表混乱是一个坏主意™,我真的不知道我在做什么。使用以下脚本自行风险,并准备好让您的IT部门重新对象您的机器,并询问您对您在做什么的不舒服问题。

在源机上:

.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:SoftwareSimonTatham"
# Only sessions
#$registry_path = "HKCU:SoftwareSimonTathamPuTTYSessions"
$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并不熟悉。欢迎改进!

如果要在PuTTY Portable上导入设置,则可以使用putty.reg文件。

只需将其放入此路径[path_to_Your_portable_apps]PuTTYPortableDatasettingsputty.reg即可。程序将导入IT

,对于需要从离线注册表文件中导入腻子的人,例如。当您从崩溃的系统中恢复或简单地转移到新机器并从该旧驱动器上获取数据时,还有一个值得一提的解决方案:

http://www.nirsoft.net/utils/registry_file_offline_export.html

此出色且免费的控制台应用程序将导出整个注册表或一个特定的注册表密钥。就我而言,我只是将注册表文件从旧驱动器复制到与出口工具相同的目录,然后在CMD窗口中使用以下命令和语法作为管理员:

regfileexport.exe ntuser.dat putty.reg" hkey_current_user software software simontatham"

导入.reg文件并启动Putty之后,所有内容都在那里。简单而高效的。

对于那些不想弄乱注册表的人,已经创建了一种保存到文件的果皮变体。它位于这里:http://jakub.kotrla.net/putty/

如果油灰团队将其作为主要分布的选择,那将是很好的。

m0nhawk的答案对我不起作用Windows 10-它需要提高命令提示,并拒绝发出文件。

这有效,不需要高程:

reg export HKEY_CURRENT_USERSoftwareSimonTathamPuTTY putty.reg

示例:
如何将"腻子配置"one_answers"会话配置"从一个用户帐户传输到另一个用户帐户。创建一个新帐户并想从旧帐户使用腻子会话/配置

进程:
- 从旧帐户的导出注册表密钥

- 导入注册表密钥从文件中

导出reg键: (来自旧帐户)

  1. 登录到旧帐户,例如Tomold
  2. 打开普通"命令提示"(不是admin!)
  3. 类型'regedit'
  4. 导航到存储配置的注册表部分,例如[hkey_current_user software simontatham]并单击它
  5. 从"文件"菜单或右鼠标单击(无线电Ctrl'Selected Branch')
  6. 中选择"导出"
  7. 保存到文件中并命名,例如'puttyconfig.reg'
  8. 再次注销

导入reg键: (进入新帐户)

  1. 登录到新帐户,例如汤姆

  2. 打开常规'命令提示'(不是admin!)

  3. 类型'regedit'

  4. 从菜单中选择"导入"

  5. 选择要导入的注册表文件'puttyconfig.reg'

  6. 完成

注意:
请勿使用" admin命令提示符",因为设置位于" [hkey_current_user ...]'下方,并且regedit将作为admin运行,并显示为管理用户的部分,而不是供用户从和/或转移。

这比上述注册表的导出要容易得多。 简单:

  1. 右键单击文件,
  2. 选择"合并"

在Win 7 Pro中像冠军一样工作。

如果您像我一样,安装了新窗口,并且仅在之后才安装您还记得关于油灰会话,如果您有旧的Windows硬盘驱动器或至少您的旧"家"目录备份(C:Users<user_name>)。

在此目录中应该有NTUSER.DAT文件。默认情况下它是隐藏的,因此您应该在Windows资源管理器中启用隐藏的文件或使用其他文件浏览器。该文件包含旧Windows注册表的HKEY_CURRENT_USER分支。

要使用它,您需要在新窗口上打开regedit,然后选择HKEY_USERS键。

然后选择File-> Load Hive...,然后找到旧Windows安装的旧"家"目录。在此目录中应该有NTUSER.DAT文件。默认情况下它是隐藏的,因此,如果您不能在Windows Explorer属性中显示隐藏的文件,则可以手动将文件名输入File name输入框"加载Hive"对话框的输入框,然后按 Enter 。然后在下一个对话框窗口中输入一些密钥名称,将旧注册表加载到其中。例如tmp

现在应该在您当前注册表的HKEY_USERStmp分支下访问您的旧注册表的HKEY_CURRENT_USER分支。

现在,将HKEY_USERStmpSoftwareSimonTatham分支将其导出到putty.reg文件中,在您喜欢的文本编辑器中打开此文件,并将所有HKEY_USERStmp字符串带有HKEY_CURRENT_USER。现在保存.reg文件。

现在,您可以通过双击它将此文件导入当前的Windows注册表中。请参阅M0nhawk的答案。

最后,选择注册表编辑器中的HKEY_USERStmp分支,然后选择File-> Unload Hive...并确认此操作。

对解决方案的改进bumerang将数据导入PuTTY portable

简单地将导出的putty.reg(带有M0NHAWK解决方案)移至PuTTYPortableDatasettings不起作用。油灰便携式备份文件并创建一个新的空数据。

要解决此问题,请将putty.reg合并,手动复制您要从导出的putty.reg迁移的配置,以下以下新创建的PuTTYPortableDatasettingsputty.reg以下行。

REGEDIT4
[HKEY_CURRENT_USERSoftwareSimonTathamPuTTY]
"RandSeedFile"="D:\Programme\PuTTYPortable\Data\settings\PUTTY.RND"

@m0nhawk发布的答案似乎在我在Windows 7机器上测试时似乎不起作用。相反,使用以下脚本将导出/导入Putty的设置:

::export
@echo off
set regfile=putty.reg
pushd %~dp0
reg export HKCUSoftwareSimonTatham %regfile% /y
popd

-

::import
@echo off
pushd %~dp0
set regfile=putty.reg
if exist %regfile% reg import %regfile%
popd

使用此方法也可以执行质量配置更改,例如更改所有会话字体。

  1. 导出到.reg
  2. 执行搜索并替换为.reg
  3. 删除所有会话
  4. 导入新的.reg

从此处提取:http://www.sysadmit.com/2015/11/putty-exportar-configuracion.html

<<div class =" ans">

有一个ratil.life/first-use-use-powershell-script-putty-putty-ssh-config上的powershell脚本,可以将会话转换为可以在.ssh/config中使用的格式。也可以在github上找到。

此摘录包含代码的主要胆量,并将直接打印出结果的配置:

# Registry path to PuTTY configured profiles
$regPath = 'HKCU:SOFTWARESimonTathamPuTTYSessions'
# 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 }
    }
}

我使用Putty Connection Manager创建会话数据库。将数据库复制和导入到其他计算机很容易。

请参阅此方便的指南

最新更新