Bekerja dengan Keupayaan Linux

Pengenalan

Keupayaan Linux adalah atribut khas dalam kernel Linux yang memberikan proses dan binari yang boleh digunakan khusus keistimewaan yang biasanya digunakan untuk proses yang ID pengguna yang berkesan adalah 0 (Pengguna root, dan hanya pengguna root, mempunyai UID 0).

Artikel ini akan menerangkan beberapa keupayaan yang ada, kegunaan mereka dan cara menetapkan dan membuangnya. Sila ambil perhatian bahawa keupayaan penetapan pada laku laku boleh berpotensi untuk menjejaskan keselamatan sistem anda. Oleh itu, anda harus mempertimbangkan ujian pada sistem bukan pengeluaran sebelum melaksanakan keupayaan dalam pengeluaran.

Prasyarat

  • Sistem Linux di mana anda mempunyai akses root (sama ada melalui pengguna root atau pengguna dengan akses sudo).

Penjelasan

Pada asasnya, tujuan keupayaan adalah untuk membahagikan kekuatan 'root' menjadi hak istimewa, sehingga jika proses atau binari yang memiliki satu atau lebih kemampuan dieksploitasi, potensi kerosakan terbatas jika dibandingkan dengan proses yang sama seperti root.

Keupayaan dapat ditetapkan pada proses dan fail yang dapat dilaksanakan. Proses yang dihasilkan daripada pelaksanaan fail boleh mendapatkan keupayaan fail tersebut.

Keupayaan yang dilaksanakan di Linux banyak, dan banyak yang telah ditambahkan sejak dilancarkan asalnya. Sebahagian daripada mereka adalah seperti berikut:

  • CAP_CHOWN: Buat perubahan pada ID Pengguna dan ID Kumpulan fail
  • CAP_DAC_OVERRIDE: Ganti DAC (Kawalan Akses Discretionary). Contohnya, vto memintas membaca / menulis / melaksanakan pemeriksaan kebenaran.
  • CAP_KILL: Bypass cek kebenaran untuk menghantar isyarat kepada proses.
  • CAP_SYS_NICE: Naikkan kebaikan proses ( Penjelasan mengenai kebaikan boleh didapati di sini )
  • CAP_SYS_TIME: Tetapkan sistem dan jam perkakasan masa nyata

Untuk senarai penuh, jalankan man 7 capabilities.

Keupayaan diberikan dalam kumpulan, iaitu "dibenarkan", "diwarisi", "berkesan" dan "ambien" untuk utas, dan "dibenarkan", "diwarisi" dan "berkesan" untuk fail. Set ini mentakrifkan tingkah laku yang berbeza, penjelasan lengkapnya adalah di luar skop artikel ini.

Semasa menetapkan keupayaan pada fail, kita akan selalu menggunakan "dibenarkan" dan "berkesan", misalnya CAP_DAC_OVERRIDE+ep. Perhatikan +ep, yang menandakan set tersebut di atas.

Bekerja dengan keupayaan fail

Pakej yang diperlukan

Terdapat dua alat utama, getcapdan setcapmasing-masing boleh melihat dan menetapkan sifat-sifat ini.

  • Di Debian dan Ubuntu, alat ini disediakan oleh libcap2-binpakej yang boleh dipasang dengan:apt install libcap2-bin
  • Di CentOS dan Fedora, libcappakej diperlukan:yum install libcap
  • Di Arch Linux, mereka juga disediakan oleh libcap:pacman -S libcap

Keupayaan membaca

Untuk melihat jika fail mempunyai apa-apa keupayaan yang ditetapkan, anda hanya boleh menjalankan getcap /full/path/to/binary, contohnya:

 root@demo:~# getcap /usr/bin/ping
 /usr/bin/ping = cap_net_raw+ep
 root@demo:~# getcap /usr/bin/rcp
 /usr/bin/rcp = cap_net_bind_service+ep

Sekiranya anda ingin mengetahui keupayaan mana yang sudah ditetapkan pada sistem anda, anda boleh mencari keseluruhan sistem fail anda secara berulang dengan arahan berikut:

getcap -r /

Oleh kerana fakta bahawa sistem fail maya (seperti /proc) tidak menyokong operasi ini, arahan di atas akan menghasilkan ribuan kesilapan, jadi untuk output yang lebih bersih gunakan yang berikut:

getcap -r / 2>/dev/null 

Menugaskan dan membuang keupayaan

Untuk menetapkan kemampuan tertentu pada fail, gunakan setcap "capability_string" /path/to/file.

Untuk membuang semua keupayaan dari fail, gunakan setcap -r /path/to/file.

Untuk demonstrasi kami akan membuat fail kosong di direktori semasa, memberikannya kemampuan, dan menghapusnya. Mulakan dengan yang berikut:

root@demo:~# touch testfile
root@demo:~# getcap testfile

Perintah kedua tidak menghasilkan output, yang bermaksud fail ini tidak mempunyai kemampuan.

Seterusnya, tetapkan keupayaan untuk fail:

root@demo:~# setcap "CAP_CHOWN+ep" testfile
root@demo:~# getcap testfile
testfile = cap_chown+ep

"CAP_CHOWN + ep" digunakan sebagai contoh, tetapi mana-mana yang lain boleh ditugaskan dengan cara ini.

Sekarang, alih keluar semua keupayaan dari testfile:

root@demo:~# setcap -r testfile
root@demo:~# getcap testfile

Sekali lagi, tidak akan ada output, kerana "CAP_CHOWN + ep" telah dikeluarkan.

Kesimpulannya

Keupayaan mempunyai banyak potensi penggunaan dan dapat membantu memperketat keselamatan sistem anda. Jika anda menggunakan bit SUID pada executable anda, pertimbangkan untuk menggantikannya dengan keupayaan khusus yang diperlukan.



Leave a Comment

Cara Memasang Platform Keranjang Belanja LiteCart di Ubuntu 16.04

Cara Memasang Platform Keranjang Belanja LiteCart di Ubuntu 16.04

LiteCart adalah platform keranjang belanja sumber terbuka dan bebas yang ditulis dalam PHP, jQuery, dan HTML 5. Ia adalah perisian elektronik e-dagang yang ringkas, ringan, dan mudah digunakan

Sediakan NFS Share di Debian

Sediakan NFS Share di Debian

NFS adalah sistem fail berasaskan rangkaian yang membolehkan komputer mengakses fail di seluruh rangkaian komputer. Panduan ini menerangkan bagaimana anda boleh mendedahkan folder di atas NF

Cara Memasang Matomo Analytics di Fedora 28

Cara Memasang Matomo Analytics di Fedora 28

Menggunakan Sistem Berbeza? Matomo (dahulunya Piwik) adalah platform analitik sumber terbuka, alternatif terbuka kepada Google Analytics. Sumber Matomo dihoskan o

Sediakan Pelayan TeamTalk di Linux

Sediakan Pelayan TeamTalk di Linux

TeamTalk adalah sistem persidangan yang membolehkan pengguna melakukan perbincangan audio / video berkualiti tinggi, sembang teks, memindahkan fail, dan berbagi layar. Ia i

Cara Pasang dan Konfigur CyberPanel pada Server CentOS 7 anda

Cara Pasang dan Konfigur CyberPanel pada Server CentOS 7 anda

Menggunakan Sistem Berbeza? Pengenalan CyberPanel adalah salah satu panel kawalan pertama di pasaran yang merupakan sumber terbuka dan menggunakan OpenLiteSpeed. Apa itu

Cara Memasang Apache Maven 3.5 di CentOS 7

Cara Memasang Apache Maven 3.5 di CentOS 7

Apache Maven adalah alat pengurusan projek perisian sumber terbuka dan bebas yang banyak digunakan untuk menyebarkan aplikasi berbasis Java. Prasyarat yang baru

Cara Memasang Backdrop CMS 1.8.0 pada VPS CentOS 7 LAMP

Cara Memasang Backdrop CMS 1.8.0 pada VPS CentOS 7 LAMP

Menggunakan Sistem Berbeza? Backdrop CMS 1.8.0 adalah Sistem Pengurusan Kandungan (CMS) sumber mudah alih, mudah alih, percuma dan terbuka yang membolehkan kami

Cara Mengakses VPS Vultr Anda

Cara Mengakses VPS Vultr Anda

Vultr menyediakan beberapa cara yang berbeza untuk mengakses VPS anda untuk mengkonfigurasi, memasang, dan menggunakan. Akses Kredensial Kelayakan akses lalai untuk VPS anda

Cara Membangun Brotli Dari Sumber di Ubuntu 18.04 LTS

Cara Membangun Brotli Dari Sumber di Ubuntu 18.04 LTS

Menggunakan Sistem Berbeza? Brotli adalah kaedah pemampatan baru dengan nisbah mampatan yang lebih baik daripada GZIP. Kod sumbernya dihoskan secara umum di Githu ini

Menggunakan Paparan MySQL pada Debian 7

Menggunakan Paparan MySQL pada Debian 7

Pengenalan MySQL mempunyai ciri hebat yang dikenali sebagai pandangan. Paparan adalah pertanyaan yang disimpan. Anggap mereka sebagai alias untuk pertanyaan yang panjang. Dalam panduan ini,

Cara Pasang AirSonic pada CentOS 7

Cara Pasang AirSonic pada CentOS 7

Menggunakan Sistem Berbeza? AirSonic adalah pelayan streaming media sumber terbuka dan terbuka. Dalam tutorial ini, saya akan membimbing anda melalui proses penyebaran a

Cara Pasang CD Strider pada Ubuntu 18.04

Cara Pasang CD Strider pada Ubuntu 18.04

Pengenalan CD Strider adalah platform penyebaran sumber terbuka berterusan. Aplikasi ini ditulis dalam Node.js dan menggunakan MongoDB sebagai backend penyimpanan. Selesaikan

Cara Memasang Subrion 4.1 CMS pada Ubuntu 16.04 LAMP VPS

Cara Memasang Subrion 4.1 CMS pada Ubuntu 16.04 LAMP VPS

Menggunakan Sistem Berbeza? Subrion 4.1 CMS adalah Sistem Pengurusan Kandungan sumber terbuka (CMS) yang kuat dan fleksibel yang membawa kandungan intuitif dan jelas

Cara Pasang DokuWiki pada Ubuntu 16.04 LTS

Cara Pasang DokuWiki pada Ubuntu 16.04 LTS

Menggunakan Sistem Berbeza? DokuWiki adalah program wiki sumber terbuka yang ditulis dalam PHP yang tidak memerlukan pangkalan data. Ia menyimpan data dalam fail teks. DokuWik

Siapkan Komposer Untuk Ketergantungan PHP Di CentOS 6

Siapkan Komposer Untuk Ketergantungan PHP Di CentOS 6

Pengenalan Komposer adalah pengurus pergantungan yang popular untuk PHP yang dapat mempermudah pemasangan dan kemas kini perpustakaan yang diperlukan untuk projek anda

Menyiapkan Chroot di Debian

Menyiapkan Chroot di Debian

Artikel ini akan mengajar anda cara menyediakan penjara chroot di Debian. Saya menganggap bahawa anda menggunakan Debian 7.x. Sekiranya anda menjalankan Debian 6 atau 8, ini mungkin berfungsi,

Cara Memasang PiVPN pada Debian

Cara Memasang PiVPN pada Debian

Pengenalan Cara mudah untuk menyediakan pelayan VPN di Debian adalah dengan PiVPN. PiVPN adalah pemasang dan pembungkus untuk OpenVPN. Ini membuat perintah mudah untuk anda

Cara Pasang Edisi Komuniti GitLab (CE) 11.x pada Debian 9

Cara Pasang Edisi Komuniti GitLab (CE) 11.x pada Debian 9

Menggunakan Sistem Berbeza? Sejak GitHub diambil alih oleh Microsoft, sebilangan besar pembangun telah merancang untuk memindahkan repositori kod mereka sendiri dari github.co

Pasang PBX dalam Flash 5 pada Debian 8

Pasang PBX dalam Flash 5 pada Debian 8

PBX In A Flash 5 (PIAF5) adalah sistem operasi berasaskan Debian 8 yang menjadikan Vultr VPS anda menjadi PBX lengkap. Ia mempunyai ciri-ciri berikut, dan banyak lagi.

Cara Pasang dan Konfigurasi CyberPanel pada Ubuntu 18.04 LTS

Cara Pasang dan Konfigurasi CyberPanel pada Ubuntu 18.04 LTS

Menggunakan Sistem Berbeza? Pengenalan CyberPanel adalah salah satu panel kawalan pertama di pasaran yang merupakan sumber terbuka dan menggunakan OpenLiteSpeed. Apa itu

Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1

Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1

Pandangan tentang 26 Teknik Analisis Data Besar: Bahagian 1

6 Perkara Yang Sangat Menggila Tentang Nintendo Switch

6 Perkara Yang Sangat Menggila Tentang Nintendo Switch

Ramai daripada anda tahu Switch akan keluar pada Mac 2017 dan ciri baharunya. Bagi yang tidak tahu, kami telah menyediakan senarai ciri yang menjadikan 'Tukar' sebagai 'gajet yang mesti ada'.

Janji Teknologi Yang Masih Tidak Ditepati

Janji Teknologi Yang Masih Tidak Ditepati

Adakah anda menunggu gergasi teknologi memenuhi janji mereka? semak apa yang masih belum dihantar.

Fungsi Lapisan Seni Bina Rujukan Data Besar

Fungsi Lapisan Seni Bina Rujukan Data Besar

Baca blog untuk mengetahui lapisan berbeza dalam Seni Bina Data Besar dan fungsinya dengan cara yang paling mudah.

Bagaimana AI Boleh Mengambil Automasi Proses ke Tahap Seterusnya?

Bagaimana AI Boleh Mengambil Automasi Proses ke Tahap Seterusnya?

Baca ini untuk mengetahui cara Kecerdasan Buatan semakin popular di kalangan syarikat berskala kecil dan cara ia meningkatkan kebarangkalian untuk menjadikan mereka berkembang dan memberikan pesaing mereka kelebihan.

CAPTCHA: Berapa Lama Ia Boleh Kekal Sebagai Teknik Berdaya maju Untuk Perbezaan Manusia-AI?

CAPTCHA: Berapa Lama Ia Boleh Kekal Sebagai Teknik Berdaya maju Untuk Perbezaan Manusia-AI?

CAPTCHA telah menjadi agak sukar untuk diselesaikan oleh pengguna dalam beberapa tahun kebelakangan ini. Adakah ia dapat kekal berkesan dalam pengesanan spam dan bot pada masa hadapan?

Keunikan Teknologi: Masa Depan Tamadun Manusia yang Jauh?

Keunikan Teknologi: Masa Depan Tamadun Manusia yang Jauh?

Apabila Sains Berkembang pada kadar yang pantas, mengambil alih banyak usaha kita, risiko untuk menundukkan diri kita kepada Ketunggalan yang tidak dapat dijelaskan juga meningkat. Baca, apakah makna ketunggalan bagi kita.

Teleperubatan Dan Penjagaan Kesihatan Jauh: Masa Depan Ada Di Sini

Teleperubatan Dan Penjagaan Kesihatan Jauh: Masa Depan Ada Di Sini

Apakah teleperubatan, penjagaan kesihatan jauh dan impaknya kepada generasi akan datang? Adakah ia tempat yang baik atau tidak dalam situasi pandemik? Baca blog untuk mencari paparan!

Pernahkah Anda Terfikir Bagaimana Penggodam Mendapatkan Wang?

Pernahkah Anda Terfikir Bagaimana Penggodam Mendapatkan Wang?

Anda mungkin pernah mendengar bahawa penggodam memperoleh banyak wang, tetapi pernahkah anda terfikir bagaimana mereka memperoleh wang seperti itu? Mari berbincang.

Kemas Kini Tambahan macOS Catalina 10.15.4 Menyebabkan Lebih Banyak Isu Daripada Penyelesaian

Kemas Kini Tambahan macOS Catalina 10.15.4 Menyebabkan Lebih Banyak Isu Daripada Penyelesaian

Baru-baru ini Apple mengeluarkan macOS Catalina 10.15.4 kemas kini tambahan untuk menyelesaikan masalah tetapi nampaknya kemas kini itu menyebabkan lebih banyak masalah yang membawa kepada pemusnahan mesin mac. Baca artikel ini untuk mengetahui lebih lanjut