Puncte:0

Cu serverul Microsoft OpenSSH pentru Windows, cum cităm caracterele de spațiu în comenzile forțate din fișierul authorized_keys?

drapel ve

Avem setare Implementarea de către Microsoft a serverului OpenSSH pe un server Windows 2019 (v1809) și au activat autentificarea pe baza cheilor publice. Am dori să ne desfășurăm comenzi forțate și se luptă cu caractere spațiale din cale a unor astfel de comenzi.

Un exemplu minim:

Utilizator utilizator1 are următoarele chei_autorizate fişier:

command="C:\Program Files\SomePath\SomeProgram.exe" ssh-ed25519 AAAAC3N...

Când încercăm ssh în acea mașină ca utilizator, se întâmplă următoarele:

$ ssh -i <user1_key_id> user1@server.example.com

„C:\Program” nu este recunoscut ca o comandă internă sau externă,
program operabil sau fișier batch.
Conexiunea la server.example.com s-a închis.

(Vă rugăm să rețineți că avem un agent SSH care rulează, astfel încât să nu existe o interogare de parolă în fragmentul de sesiune de terminal de mai sus.)

IMHO, este destul de clar că problema se datorează caracterului spațiu din calea programului care ar trebui să fie executat.Cu toate acestea, nu suntem siguri de ce ghilimelele duble din jurul comenzii din chei_autorizate fișierul nu previne problema. Am încercat să adăugăm o altă pereche de ghilimele duble folosind binecunoscutele metode de evadare:

command="\"C:\Program Files\SomePath\SomeProgram.exe\""...

command="^"C:\Program Files\SomePath\SomeProgram.exe^""...
command="""C:\Program Files\SomePath\SomeProgram.exe"""...

Prima duce la aceeași eroare ca cea descrisă mai sus. Al doilea și al treilea duc la un alt mesaj de eroare:

user1@server.example.com: Permisiune refuzată (cheie publică).

Acum suntem blocați și avem următoarea întrebare:

Cum trebuie să scriem comanda de mai sus în cheie_autorizată fișiere pentru serverul Microsoft OpenSSH pentru Windows?

Puncte:1
drapel cn

Comanda care urmează să fie executată este întreaga linie după numele „command=".

Sunt necesare ghilimele pentru a proteja spațiile din calea executabilului dvs. pe serverul țintă.
Citatele din fișierul authorized_keys trebuie să fie eliminate cu bare oblice inverse:

Deci, ar trebui să arate cam așa:

command=\"C:\Program Files\SomePath\SomeProgram.exe\" ssh-ed25519 AAAAC3N...
Binarus avatar
drapel ve
Mulțumesc foarte mult și +1. Cu toate acestea, acest lucru duce la eroarea „permisiune refuzată” descrisă în postarea mea inițială...

Postează un răspuns

Majoritatea oamenilor nu înțeleg că a pune multe întrebări deblochează învățarea și îmbunătățește legătura interpersonală. În studiile lui Alison, de exemplu, deși oamenii își puteau aminti cu exactitate câte întrebări au fost puse în conversațiile lor, ei nu au intuit legătura dintre întrebări și apreciere. În patru studii, în care participanții au fost implicați în conversații ei înșiși sau au citit transcrieri ale conversațiilor altora, oamenii au avut tendința să nu realizeze că întrebarea ar influența – sau ar fi influențat – nivelul de prietenie dintre conversatori.