มีวิธีทำเช่นนี้หรือไม่?
หรือฉันต้องบันทึกทุกครั้งจาก Registry ด้วยตนเอง?
มีวิธีทำเช่นนี้หรือไม่?
หรือฉันต้องบันทึกทุกครั้งจาก Registry ด้วยตนเอง?
คำตอบ:
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 เพื่อทำการโหลด
คำเตือน : ล้อเล่นกับรีจิสทรีเช่นนี้คือ 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 ยินดีต้อนรับการปรับปรุง!
เรียกใช้เรียกใช้จากนั้นพิมพ์ในหน้าต่างเปิดแบบเลื่อนลง: regedit
นำทางไปเช่นเดียวกับใน Explorer ของ Window:
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/
มันจะดีถ้าทีมงานฉาบจะใช้สิ่งนี้เป็นตัวเลือกในการกระจายหลัก
ตัวอย่าง:
วิธีการถ่ายโอนการกำหนดค่าโป๊วและการกำหนดค่าเซสชันจากบัญชีผู้ใช้หนึ่งไปยังอีกบัญชีหนึ่งเช่นเมื่อสร้างบัญชีใหม่และต้องการใช้เซสชัน / การกำหนดรูปแบบโป๊วจากบัญชีเก่า
กระบวนการ:
- ส่งออกรีจิสตรีคีย์จากบัญชีเก่าไปยังไฟล์
- อิมพอร์ตรีจิสตรีคีย์จากไฟล์ไปยังบัญชีใหม่
ส่งออกรหัส reg: (จากบัญชี OLD)
คีย์การนำเข้า reg: (เข้าบัญชีใหม่)
ลงชื่อเข้าใช้บัญชีใหม่เช่น tom
เปิด 'พรอมต์คำสั่ง' ปกติ (ไม่ใช่ผู้ดูแลระบบ!)
พิมพ์ 'regedit'
เลือก 'นำเข้า' จากเมนู
เลือกไฟล์รีจิสตรีเพื่อนำเข้าเช่น 'puttyconfig.reg'
เสร็จสิ้น
หมายเหตุ:
อย่าใช้ 'พรอมต์คำสั่งผู้ดูแลระบบ' เนื่องจากการตั้งค่าอยู่ภายใต้ '[HKEY_CURRENT_USER ... ]' 'และ regedit จะทำงานเป็นผู้ดูแลระบบและแสดงส่วนนั้นสำหรับผู้ใช้ที่เป็นผู้ดูแลระบบแทนเพื่อให้ผู้ใช้ถ่ายโอนจากและ / หรือ ถึง.
การปรับปรุงการแก้ปัญหาของ 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"
คำตอบที่โพสต์โดย @ 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
คำตอบของ m0nhawk ไม่ได้ผลสำหรับฉันใน Windows 10 - มันต้องการพรอมต์คำสั่งที่ได้รับการยกระดับและปฏิเสธที่จะปล่อยไฟล์
สิ่งนี้ใช้ได้ผลและไม่ต้องการการยกระดับ:
reg export HKEY_CURRENT_USER\Software\SimonTatham\PuTTY putty.reg
การใช้วิธีนี้ยังเป็นไปได้ที่จะทำการเปลี่ยนแปลงการกำหนดค่าจำนวนมากเช่นการเปลี่ยนแบบอักษรเซสชันทั้งหมด
แยกมาจากที่นี่: http://www.sysadmit.com/2015/11/putty-exportar-configuracion.html
ฉันใช้ตัวจัดการการเชื่อมต่อที่ฉาบ ซึ่งคุณสร้างฐานข้อมูลของเซสชัน ง่ายต่อการคัดลอกและนำเข้าฐานข้อมูลนั้นไปยังคอมพิวเตอร์เครื่องอื่น
ดูคู่มือที่มีประโยชน์นี้
มีสคริปต์ 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 }
}
}
หากคุณเช่นฉันติดตั้ง 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...
และยืนยันการดำเนินการนี้