จะส่งออก / นำเข้ารายการเซสชัน PuTTy ได้อย่างไร


คำตอบ:


1238

ส่งออก

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 ที่เกี่ยวข้อง


3
@NamGVU นั่นเป็นเพราะพา ธ มีโฟลเดอร์ที่มีช่องว่าง ย้ายไปยังที่ที่ไม่มี
m0nhawk

3
@NamGVU อย่าแทนที่% userprofile% ด้วยชื่อผู้ใช้ของคุณทิ้งไว้เหมือนเดิม
Asrar

4
คุณจะนำเข้ามันลงใน Putty อื่นในเครื่องอื่นได้อย่างไร
Pete

4
โอเคดับเบิลคลิก ... รับไปเลย
Pete

7
คำสั่งที่สองทำงานให้ฉันบน Windows 7 อย่างไรก็ตามฉันจำเป็นต้องเรียกใช้ CMD ในฐานะผู้ดูแลระบบ
หนูต่ำต้อย

46

เมื่อฉันลองวิธีอื่นฉันได้รับข้อผิดพลาดนี้:

Registry editing has been disabled by your administrator.

ฉันพูดไป!

ฉันรวบรวมสคริปต์ PowerShell ด้านล่างสำหรับการส่งออกและนำเข้าการตั้งค่า PuTTY ไฟล์ที่ส่งออกเป็นไฟล์ windows. reg และจะนำเข้าอย่างสมบูรณ์หากคุณได้รับอนุญาตมิฉะนั้นให้ใช้ 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
ทำงานได้อย่างสมบูรณ์แบบประหยัดเวลา นอกจากนี้ ... ฉันต้องทำตามคำแนะนำที่นี่เพื่อตั้งค่าการอนุญาต: stackoverflow.com/questions/4037939/… .
Jacob Zwiers

1
นั่นเป็นความช่วยเหลือที่ดีมาก! ผมมีสถานที่ที่แตกต่างกันรีจิสทรีเพิ่งมีการแก้ไขเส้นทางทั้งในและที่มัน :)
SidJ

รอดังนั้น PowerShell หลีกเลี่ยงนโยบายกลุ่ม สงสัยว่านานแค่ไหนที่จะได้รับการติดตั้ง
คำถามของ

ไม่แน่ใจ แต่เราอยู่ที่สี่ปีและนับ;)
dwurf

ฉันพยายามไม่ทำงาน
Velmurugan

44
  1. เรียกใช้เรียกใช้จากนั้นพิมพ์ในหน้าต่างเปิดแบบเลื่อนลง: regedit

  2. นำทางไปเช่นเดียวกับใน Explorer ของ Window:
    HKEY_CURRENT_USER \ Software \ SimonTatham

  3. คลิกขวาที่ปุ่ม 'SimonTatham' (ไอคอนไดเรกทอรี) เลือกส่งออก
    ตั้งชื่อไฟล์ (พูด) putty.reg และบันทึกลงในตำแหน่งของคุณเพื่อ
    ใช้ในภายหลัง
  4. ปิดตัวแก้ไขรีจิสทรี

เสร็จสิ้น


34

หากคุณต้องการนำเข้าการตั้งค่าบนPuTTY Portableคุณสามารถใช้ putty.regไฟล์ได้

เพียงนำไปไว้ที่เส้นทาง[path_to_Your_portable_apps]PuTTYPortable\Data\settings\putty.regนี้ โปรแกรมจะนำเข้ามัน


23

สำหรับผู้ที่ต้องการนำเข้า 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 ทุกอย่างอยู่ที่นั่น ง่ายและมีประสิทธิภาพ


2
คำตอบนี้แคบพอสำหรับกรณีการใช้งานที่จะรวมอยู่ในคำถามแยกต่างหากสำหรับการกู้คืนแบบออฟไลน์ ขอบคุณ
Frank Phillips

4
ฉันจะเพิ่มบันทึกย่อที่ NTUSER.DAT อยู่ในผู้ใช้ / [ชื่อผู้ใช้] เป็นไฟล์ระบบที่ได้รับการป้องกันไม่ใช่ Windows / SYSTEM32 / Config
Frank Phillips

13

สำหรับผู้ที่ไม่ต้องการยุ่งกับรีจิสทรีมีการสร้างรูปแบบของสีโป๊วที่บันทึกไว้ในไฟล์ ตั้งอยู่ที่นี่: http://jakub.kotrla.net/putty/

มันจะดีถ้าทีมงานฉาบจะใช้สิ่งนี้เป็นตัวเลือกในการกระจายหลัก


13

นี่คือการนำเข้าการส่งออกรีจิสตรีได้ง่ายกว่าที่ระบุไว้ข้างต้น + เพียง:

  1. คลิกขวาที่ไฟล์และ
  2. เลือก "ผสาน"

ทำงานเหมือนแชมป์ใน Win 7 Pro


2
ทำงานให้กับฉันใน Windows 10 ด้วย
Jan

3
ฉันสามารถยืนยันได้ - มันทำงานได้อย่างไม่มีที่ติใน Win10 "นำเข้า" ที่ง่ายที่สุดเท่าที่เคยมีมา ขอบคุณ!
d-wade

10

ตัวอย่าง:
วิธีการถ่ายโอนการกำหนดค่าโป๊วและการกำหนดค่าเซสชันจากบัญชีผู้ใช้หนึ่งไปยังอีกบัญชีหนึ่งเช่นเมื่อสร้างบัญชีใหม่และต้องการใช้เซสชัน / การกำหนดรูปแบบโป๊วจากบัญชีเก่า

กระบวนการ:
- ส่งออกรีจิสตรีคีย์จากบัญชีเก่าไปยังไฟล์
- อิมพอร์ตรีจิสตรีคีย์จากไฟล์ไปยังบัญชีใหม่

ส่งออกรหัส reg: (จากบัญชี OLD)

  1. ลงชื่อเข้าใช้บัญชี OLD เช่น tomold
  2. เปิด 'พรอมต์คำสั่ง' ปกติ (ไม่ใช่ผู้ดูแลระบบ!)
  3. พิมพ์ 'regedit'
  4. นำทางไปยังส่วนรีจิสตรีที่มีการจัดเก็บการกำหนดค่าเช่น [HKEY_CURRENT_USER \ SOFTWARE \ SimonTatham] และคลิกที่มัน
  5. เลือก 'ส่งออก' จากเมนูไฟล์หรือคลิกเมาส์ขวา (วิทยุ ctrl 'สาขาที่เลือก')
  6. บันทึกลงในไฟล์และตั้งชื่อเช่น 'puttyconfig.reg'
  7. ออกจากระบบอีกครั้ง

คีย์การนำเข้า reg: (เข้าบัญชีใหม่)

  1. ลงชื่อเข้าใช้บัญชีใหม่เช่น tom

  2. เปิด 'พรอมต์คำสั่ง' ปกติ (ไม่ใช่ผู้ดูแลระบบ!)

  3. พิมพ์ 'regedit'

  4. เลือก 'นำเข้า' จากเมนู

  5. เลือกไฟล์รีจิสตรีเพื่อนำเข้าเช่น 'puttyconfig.reg'

  6. เสร็จสิ้น

หมายเหตุ:
อย่าใช้ 'พรอมต์คำสั่งผู้ดูแลระบบ' เนื่องจากการตั้งค่าอยู่ภายใต้ '[HKEY_CURRENT_USER ... ]' 'และ regedit จะทำงานเป็นผู้ดูแลระบบและแสดงส่วนนั้นสำหรับผู้ใช้ที่เป็นผู้ดูแลระบบแทนเพื่อให้ผู้ใช้ถ่ายโอนจากและ / หรือ ถึง.


9

การปรับปรุงการแก้ปัญหาของ 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"

8

คำตอบที่โพสต์โดย @ 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

7

คำตอบของ m0nhawk ไม่ได้ผลสำหรับฉันใน Windows 10 - มันต้องการพรอมต์คำสั่งที่ได้รับการยกระดับและปฏิเสธที่จะปล่อยไฟล์

สิ่งนี้ใช้ได้ผลและไม่ต้องการการยกระดับ:

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

6

การใช้วิธีนี้ยังเป็นไปได้ที่จะทำการเปลี่ยนแปลงการกำหนดค่าจำนวนมากเช่นการเปลี่ยนแบบอักษรเซสชันทั้งหมด

  1. ส่งออกเป็น. reg
  2. ทำการค้นหาและแทนที่. reg
  3. ลบเซสชันทั้งหมด
  4. นำเข้า. reg ใหม่

แยกมาจากที่นี่: http://www.sysadmit.com/2015/11/putty-exportar-configuracion.html


3

ฉันใช้ตัวจัดการการเชื่อมต่อที่ฉาบ ซึ่งคุณสร้างฐานข้อมูลของเซสชัน ง่ายต่อการคัดลอกและนำเข้าฐานข้อมูลนั้นไปยังคอมพิวเตอร์เครื่องอื่น

ดูคู่มือที่มีประโยชน์นี้


3

มีสคริปต์ PowerShell ที่ratil.life/first-useful-powershell-script-putty-to-ssh-configซึ่งสามารถแปลงเซสชันเป็นรูปแบบที่สามารถใช้งาน.ssh/configได้ นอกจากนี้ยังสามารถพบได้ในGitHub 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 }
    }

}

2

หากคุณเช่นฉันติดตั้ง Windows ใหม่และหลังจากคุณจำเกี่ยวกับเซสชันที่มีสีโป๊วคุณยังสามารถนำเข้าได้หากคุณมีฮาร์ดไดรฟ์ Windows รุ่นเก่าหรืออย่างน้อยไดเรกทอรี "บ้าน" เก่าของคุณสำรอง ( C:\Users\<user_name>)

ในไดเรกทอรีนี้ควรมีNTUSER.DATไฟล์ มันถูกซ่อนไว้ตามค่าเริ่มต้นดังนั้นคุณควรเปิดใช้งานไฟล์ที่ซ่อนอยู่ใน Windows explorer ของคุณหรือใช้เบราว์เซอร์ไฟล์อื่น ไฟล์นี้มี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...และยืนยันการดำเนินการนี้

โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.