cari
Rumahpembangunan bahagian belakangGolangssh dilaksanakan oleh golang
ssh dilaksanakan oleh golangMay 15, 2023 am 11:02 AM

Dalam beberapa tahun kebelakangan ini, Golang semakin popular dalam bidang pembangunan. Struktur sintaksnya yang ringkas dan cekap, prestasi konkurensi yang baik dan perpustakaan standard yang luar biasa menjadikannya bahasa pilihan bagi kebanyakan pembangun.

Dalam keselamatan rangkaian, protokol SSH ialah protokol penyulitan yang biasa digunakan yang boleh melindungi keselamatan data sensitif semasa penghantaran rangkaian. Dalam banyak bidang, seperti pengurusan pelayan, kakitangan operasi dan penyelenggaraan selalunya perlu menggunakan SSH untuk menyambung ke pelayan untuk operasi. Artikel ini akan menerangkan cara menulis klien SSH menggunakan Golang.

Pengenalan kepada protokol SSH

SSH ialah singkatan Secure Shell, iaitu protokol rangkaian yang digunakan untuk menyediakan saluran penghantaran selamat untuk perkhidmatan rangkaian dalam rangkaian yang tidak selamat. SSH menyokong fungsi seperti pelaksanaan arahan jauh, pemindahan fail dan terowong TCP/IP.

Protokol SSH mempunyai dua versi, iaitu SSH-1 dan SSH-2, yang terakhir adalah versi terkini. SSH-2 termasuk bahagian berikut:

  • Protokol Lapisan Pengangkutan
  • Protokol Pengesahan Pengguna
  • Protokol Sambungan)
  • Protokol Saluran (Protokol Saluran )

Dalam protokol SSH, proses jabat tangan tiga hala diperlukan antara klien dan pelayan untuk mewujudkan sambungan. Selepas jabat tangan yang berjaya, kedua-dua pihak berunding dengan algoritma penyulitan, pengesahan dan pemampatan yang hendak digunakan. Setelah rundingan selesai, komunikasi disulitkan, memastikan keselamatan data.

Di Golang, kami boleh menggunakan perpustakaan rasmi golang.org/x/crypto/ssh untuk melaksanakan sambungan dan operasi klien SSH.

Pelaksanaan klien SSH

Menyambung ke pelayan

Untuk menyambung ke pelayan, kita perlu mencipta klien SSH dahulu. Ini boleh dicapai dengan mencipta ssh.Client.

   config := &ssh.ClientConfig{
      User: "root",
      Auth: []ssh.AuthMethod{
         ssh.Password("password"),
      },
      HostKeyCallback: ssh.InsecureIgnoreHostKey(),
   }

   addr := "example.com:22"
   client, err := ssh.Dial("tcp", addr, config)
   if err != nil {
      log.Fatal("Failed to dial: ", err)
   }
   defer client.Close()

Dalam kod di atas, config mentakrifkan maklumat konfigurasi pelanggan, termasuk nama pengguna, kata laluan dan alamat hos, dsb. Parameter HostKeyCallback digunakan untuk menentukan fungsi panggil balik pengesahan sijil Di sini kami menggunakan fungsi ssh.InsecureIgnoreHostKey() untuk melangkau pengesahan sijil. Fungsi

Dial digunakan untuk mewujudkan sambungan, dengan tcp menunjukkan penggunaan protokol TCP/IP untuk menyambung, addr ialah alamat pelayan dan config ialah maklumat konfigurasi klien.

Laksanakan arahan

Selepas sambungan berjaya, kita boleh menggunakan ssh.Session untuk melaksanakan arahan. ssh.Session ialah sesi, serupa dengan terminal interaktif, di mana perintah boleh dilaksanakan.

   session, err := client.NewSession()
   if err != nil {
      log.Fatal("Failed to create session: ", err)
   }
   defer session.Close()

   var b bytes.Buffer
   session.Stdout = &b

   if err := session.Run("ls -l"); err != nil {
      log.Fatal("Failed to run: " + err.Error())
   }
   fmt.Println(b.String())

Dalam kod di atas, kami mencipta objek ssh.Session baharu dan menggunakan fungsi client.NewSession() untuk melaksanakannya. Kami mengarahkan output standard ke dalam objek bytes.Buffer untuk kemudian mengeluarkan hasil pelaksanaan arahan.

Gunakan fungsi session.Run("ls -l") untuk melaksanakan arahan. Jika perlaksanaan berjaya, keputusan akan ditulis ke output standard. Akhir sekali, kami mengeluarkan hasil pelaksanaan arahan.

Pemindahan Fail

Pelanggan SSH juga boleh menggunakan protokol sftp untuk pemindahan fail. Kita boleh menggunakan fungsi ssh.Client.NewSFTP() untuk mencipta pelanggan sftp.

   sftp, err := client.NewSFTP()
   if err != nil {
      log.Fatal("Failed to create SFTP client: ", err)
   }
   defer sftp.Close()

Dalam kod di atas, kami mencipta objek ssh.SFTP baharu dan menggunakan fungsi client.NewSFTP() untuk melaksanakannya.

Seterusnya, kami boleh menggunakan klien sftp untuk memuat naik dan memuat turun fail.

   localFile := "/path/to/local/file"
   remoteFile := "/path/to/remote/file"
   
   // 上传文件
   srcFile, err := os.Open(localFile)
   if err != nil {
      log.Fatal("Failed to open local file: ", err)
   }
   defer srcFile.Close()

   dstFile, err := sftp.Create(remoteFile)
   if err != nil {
      log.Fatal("Failed to create remote file: ", err)
   }
   defer dstFile.Close()

   if _, err := io.Copy(dstFile, srcFile); err != nil {
      log.Fatal("Failed to upload file: ", err)
   }

   // 下载文件
   remoteFile := "/path/to/remote/file"
   localFile := "/path/to/local/file"

   srcFile, err := sftp.Open(remoteFile)
   if err != nil {
      log.Fatal("Failed to open remote file: ", err)
   }
   defer srcFile.Close()

   dstFile, err := os.Create(localFile)
   if err != nil {
      log.Fatal("Failed to create local file: ", err)
   }
   defer dstFile.Close()

   if _, err := io.Copy(dstFile, srcFile); err != nil {
      log.Fatal("Failed to download file: ", err)
   }

Dalam kod untuk memuat naik fail, kami mula-mula membuka fail tempatan dan fail jauh, kemudian gunakan fungsi sftp.Create() untuk mencipta fail jauh dan menulis kandungan fail tempatan ke fail jauh.

Dalam kod untuk memuat turun fail, kami mula-mula membuka fail jauh dan fail setempat, kemudian gunakan fungsi sftp.Open() untuk membuka fail jauh dan menulis kandungan fail jauh ke fail setempat.

Ringkasan

Artikel ini memperkenalkan cara menggunakan Golang untuk menulis klien SSH untuk melaksanakan fungsi seperti menyambung ke pelayan, melaksanakan arahan dan memuat naik serta memuat turun fail. Sudah tentu, ini hanyalah contoh mudah, dan lebih banyak operasi dan pemprosesan mungkin diperlukan dalam aplikasi sebenar. Saya harap pembaca dapat memahami dan menguasai penggunaan klien SSH di Golang melalui perkongsian artikel ini.

Atas ialah kandungan terperinci ssh dilaksanakan oleh golang. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Bagaimana anda menggunakan alat PPROF untuk menganalisis prestasi GO?Bagaimana anda menggunakan alat PPROF untuk menganalisis prestasi GO?Mar 21, 2025 pm 06:37 PM

Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Bagaimana anda menulis ujian unit di GO?Bagaimana anda menulis ujian unit di GO?Mar 21, 2025 pm 06:34 PM

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Bagaimana saya menulis objek dan stub untuk ujian di GO?Bagaimana saya menulis objek dan stub untuk ujian di GO?Mar 10, 2025 pm 05:38 PM

Artikel ini menunjukkan penciptaan dan stub di GO untuk ujian unit. Ia menekankan penggunaan antara muka, menyediakan contoh pelaksanaan mengejek, dan membincangkan amalan terbaik seperti menjaga mocks fokus dan menggunakan perpustakaan penegasan. Articl

Apakah kelemahan debian opensslApakah kelemahan debian opensslApr 02, 2025 am 07:30 AM

OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO?Bagaimana saya boleh menentukan kekangan jenis tersuai untuk generik di GO?Mar 10, 2025 pm 03:20 PM

Artikel ini meneroka kekangan jenis adat Go untuk generik. Ia memperincikan bagaimana antara muka menentukan keperluan jenis minimum untuk fungsi generik, meningkatkan keselamatan jenis dan kebolehgunaan semula kod. Artikel ini juga membincangkan batasan dan amalan terbaik

Terangkan tujuan Pakej Refleksi Go. Bilakah anda akan menggunakan refleksi? Apakah implikasi prestasi?Terangkan tujuan Pakej Refleksi Go. Bilakah anda akan menggunakan refleksi? Apakah implikasi prestasi?Mar 25, 2025 am 11:17 AM

Artikel ini membincangkan pakej GO's Reflect, yang digunakan untuk manipulasi kod runtime, bermanfaat untuk siri, pengaturcaraan generik, dan banyak lagi. Ia memberi amaran tentang kos prestasi seperti pelaksanaan yang lebih perlahan dan penggunaan memori yang lebih tinggi, menasihati penggunaan yang bijak dan terbaik

Bagaimana anda menggunakan ujian yang didorong oleh jadual di GO?Bagaimana anda menggunakan ujian yang didorong oleh jadual di GO?Mar 21, 2025 pm 06:35 PM

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a

Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya?Bagaimana saya boleh menggunakan alat pengesanan untuk memahami aliran pelaksanaan aplikasi saya?Mar 10, 2025 pm 05:36 PM

Artikel ini meneroka menggunakan alat pengesanan untuk menganalisis aliran pelaksanaan aplikasi GO. Ia membincangkan teknik instrumentasi manual dan automatik, membandingkan alat seperti Jaeger, Zipkin, dan OpenTelemetry, dan menonjolkan visualisasi data yang berkesan

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

PhpStorm versi Mac

PhpStorm versi Mac

Alat pembangunan bersepadu PHP profesional terkini (2018.2.1).