Jadual Kandungan
1 NX (DEP dalam Windows)
Canary melindungi tindanan Setiap kali fungsi dilaksanakan, nilai Canary dijana secara rawak pada tindanan. Selepas itu, apabila fungsi kembali daripada pelaksanaan, nilai Canary dikesan Jika ia tidak konsisten, sistem akan melaporkan pengecualian.
Terdapat dua mod RELRO dalam Linux:

apa itu linux nx

Apr 10, 2023 am 11:05 AM
linux

Linux nx merujuk kepada "No-eXecute", yang merupakan mekanisme perlindungan dalam Linux, iaitu, data tidak boleh laku untuk menghalang kod shell penyerang daripada cuba melaksanakan dalam kawasan data akibat limpahan semasa program keadaan operasi.

apa itu linux nx

Persekitaran pengendalian tutorial ini: sistem linux5.9.8, komputer Dell G3.

Apakah itu linux nx?

Beberapa mekanisme perlindungan yang biasa digunakan oleh program Linux

1 NX (DEP dalam Windows)

NX: No-eXecute, <.>DEP: Pencegahan Laksana Data

    bermakna data tidak boleh laku, menghalang kod shell penyerang daripada cuba melaksanakan dalam kawasan data disebabkan limpahan dalam program berjalan.
  • gcc didayakan secara lalai Pilihannya ialah:
gcc -o test test.c      // 默认情况下,开启NX保护
gcc -z execstack -o test test.c  // 禁用NX保护
gcc -z noexecstack -o test test.c  // 开启NX保护
Salin selepas log masuk
2 (ASLR)

PI: Kedudukan-. Boleh Diekstrak Bebas, ASLR: Rawak Susun Letak Ruang Alamat

    fpie/fPIE: Perlu digunakan dengan pilihan
  • untuk menghidupkan pilihan pai untuk menyusun fail boleh laku supaya elf telah berkongsi atribut perpustakaan dan boleh berada dalam memori Muat dan jalankan di mana-mana sahaja. Serupa dengannya, terdapat fpic/fPIC Mengenai penerangannya https://gcc.gnu.org/onlinedocs/gcc/Code-Gen-Options.html-pie
-fpic

	Generate position-independent code (PIC) suitable for use in a shared library, if supported for the target machine. Such code accesses all constant addresses through a global offset table (GOT). The dynamic loader resolves the GOT entries when the program starts (the dynamic loader is not part of GCC; it is part of the operating system). If the GOT size for the linked executable exceeds a machine-specific maximum size, you get an error message from the linker indicating that -fpic does not work; in that case, recompile with -fPIC instead. (These maximums are 8k on the SPARC, 28k on AArch64 and 32k on the m68k and RS/6000. The x86 has no such limit.)

	Position-independent code requires special support, and therefore works only on certain machines. For the x86, GCC supports PIC for System V but not for the Sun 386i. Code generated for the IBM RS/6000 is always position-independent.

	When this flag is set, the macros `__pic__` and `__PIC__` are defined to 1.

-fPIC

	If supported for the target machine, emit position-independent code, suitable for dynamic linking and avoiding any limit on the size of the global offset table.This option makes a difference on AArch64, m68k, PowerPC and SPARC.

	Position-independent code requires special support, and therefore works only on certain machines.

	When this flag is set, the macros `__pic__` and `__PIC__` are defined to 2.

-fpie
-fPIE

	These options are similar to -fpic and -fPIC, but the generated position-independent code can be only linked into executables. Usually these options are used to compile code that will be linked using the  -pie  GCC option.

	-fpie and -fPIE both define the macros `__pie__` and `__PIE__`. The macros have the value 1 for `-fpie` and 2 for `-fPIE`.
Salin selepas log masuk
    Perbezaan. Oleh kerana fpic/fPIC digunakan untuk menyusun perpustakaan kongsi, fpie/fPIE ialah pilihan untuk penyusunan fail pai. Dokumen itu mengatakan bahawa pustaka kongsi yang dijana oleh pic (kod bebas kedudukan) hanya boleh dipautkan ke fail boleh laku Selepas itu, anda boleh menyusun atur cara C mudah sendiri dan pai akan berjalan seperti biasa Internet berkata, kod bebas kedudukan yang dijana oleh pilihan pai boleh diandaikan berada dalam Program ini, tetapi saya tidak nampak apa-apa perbezaan antara fpie/fPIE Cuma definisi makro hanyalah perbezaan antara 1 dan 2. Nampaknya...
  • Arahan kompilasi (PIE tidak didayakan secara lalai):
gcc -fpie -pie -o test test.c    // 开启PIE
gcc -fPIE -pie -o test test.c    // 开启PIE
gcc -fpic -o test test.c         // 开启PIC
gcc -fPIC -o test test.c         // 开启PIC
gcc -no-pie -o test test.c       // 关闭PIE
Salin selepas log masuk
    ASLR (Adress Space Randomization), apabila direka pada asalnya, hanya bertanggungjawab untuk rawak alamat tindanan, perpustakaan, timbunan dan segmen lain. Nilai ASLR disimpan dalam
  • , seperti berikut: /proc/sys/kernel/randomize_va_space
0 - bermaksud mematikan proses rawak ruang alamat.

1 - bermaksud mengacak alamat asas halaman mmap, tindanan dan vdso.
2 - bermakna meningkatkan rawak timbunan (timbunan) berdasarkan 1. (Lalai)

Tukar kaedah nilainya: echo 0 > /proc/sys/kernel/randomize_va_space

vDSO: objek kongsi dinamik maya; >mmap: pemetaan ingatan.


bertanggungjawab untuk rawak alamat asas program boleh laku.
Yang berikut diambil daripada Wiki: PIE

Boleh laku bebas kedudukan (PIE) melaksanakan alamat asas rawak untuk binari boleh laku utama dan telah wujud sejak 2003. Ia menyediakan kerawak alamat yang sama kepada boleh laku utama yang digunakan untuk perpustakaan kongsi.

PIE ialah sebahagian daripada ASLR, ASLR ialah fungsi sistem dan PIE ialah pilihan kompilasi.

Nota:
Apabila memperuntukkan timbunan, terdapat dua cara: dan , yang dipanggil apabila mmap() memperuntukkan memori Apabila peruntukan kecil, brk, jika tidak mmap, 128k perbezaan. brk()malloc()3. Canary (Perlindungan Tindanan)

Canary melindungi tindanan Setiap kali fungsi dilaksanakan, nilai Canary dijana secara rawak pada tindanan. Selepas itu, apabila fungsi kembali daripada pelaksanaan, nilai Canary dikesan Jika ia tidak konsisten, sistem akan melaporkan pengecualian.

Wiki:
  • Kanari
  • atau perkataan kenari ialah nilai diketahui yang diletakkan di antara penimbal dan data kawalan pada timbunan untuk memantau limpahan penimbal Apabila penimbal melimpah, data pertama yang akan rosak biasanya ialah kenari, dan pengesahan yang gagal terhadap data kenari akan memberi amaran tentang limpahan, yang kemudiannya boleh dikendalikan, sebagai contoh, dengan membatalkan kesahihan yang rosak. data. Nilai kenari tidak boleh dikelirukan dengan nilai sentinel.
  • Seperti yang dinyatakan di atas, nilai kenari diletakkan di antara penimbal dan data kawalan Apabila penimbal melimpah, nilai akan ditulis ganti. supaya dapat dikesan Untuk menentukan sama ada terdapat ralat atau serangan. Mengurangkan serangan limpahan penimbal.

Pilihan susun:
4 RELRO (ReLocation Read Only)
gcc -o test test.c                       //默认关闭
gcc -fno-stack-protector -o test test.c  //禁用栈保护
gcc -fstack-protector -o test test.c     //启用堆栈保护,不过只为局部变量中含有 char 数组的函数插入保护代码
gcc -fstack-protector-all -o test test.c //启用堆栈保护,为所有函数插入保护代码
Salin selepas log masuk

Terdapat dua mod RELRO dalam Linux:

dan.

. RELRO separa didayakan secara lalai dalam Linux. ”Partial RELRO“”Full RELRO“

RELRO separa:

Arahan kompilasi:
    gcc -o test test.c // Didayakan separa secara lalai
  • gcc -Wl, - z,relro -o test test.c // Hidupkan sebahagian RELRO
    gcc -z lazy -o test test.c // Hidupkan sebahagian daripada

    Pelbagai bahagian fail ELF ialah disusun semula. Bahagian data dalaman (seperti .got, .dtors, dsb.) diletakkan sebelum bahagian data program (seperti .data dan .bss); >
  • Jadual GOT boleh ditulis (sepatutnya berbeza daripada di atas).
  • RELRO Penuh:
    • Arahan kompilasi:
      gcc -Wl,-z,relro,-z,now -o test test.c // Hidupkan RELRO Penuh
      gcc -z now -o test test.c / / Dayakan semua
    • Sokong semua fungsi mod Separa;
    • Seluruh jadual GOT dipetakan kepada baca sahaja.

    gcc -z norelro -o a a.c // RELRO dimatikan, iaitu Tiada RELRO

    Nota:

    • .dtors: Dipanggil apabila perpustakaan kongsi yang ditakrifkan dengan .dtors dimuatkan
    • Dalam kes bss atau ralat limpahan data, RELRO Separa dan Penuh melindungi segmen data dalam ELF daripada; sedang ditimpa. Walau bagaimanapun, hanya RELRO Penuh boleh mengurangkan serangan ganti jadual GOT, tetapi ia agak mahal kerana program perlu menghuraikan semua simbol sebelum bermula.
    • Cadangan berkaitan: "Tutorial Video Linux"

Atas ialah kandungan terperinci apa itu linux nx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

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

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Konfigurasi komputer apa yang diperlukan untuk vscode Konfigurasi komputer apa yang diperlukan untuk vscode Apr 15, 2025 pm 09:48 PM

Keperluan Sistem Kod Vs: Sistem Operasi: Windows 10 dan ke atas, MACOS 10.12 dan ke atas, pemproses pengedaran Linux: minimum 1.6 GHz, disyorkan 2.0 GHz dan ke atas memori: minimum 512 MB, disyorkan 4 GB dan ke atas ruang penyimpanan: minimum 250 mb, disyorkan 1 GB dan di atas keperluan lain:

VSCode tidak dapat memasang pelanjutan VSCode tidak dapat memasang pelanjutan Apr 15, 2025 pm 07:18 PM

Sebab -sebab pemasangan sambungan kod VS mungkin: ketidakstabilan rangkaian, kebenaran yang tidak mencukupi, isu keserasian sistem, versi kod VS terlalu lama, perisian antivirus atau gangguan firewall. Dengan menyemak sambungan rangkaian, keizinan, fail log, mengemas kini kod VS, melumpuhkan perisian keselamatan, dan memulakan semula kod VS atau komputer, anda boleh menyelesaikan masalah dan menyelesaikan masalah secara beransur -ansur.

Apr 16, 2025 pm 07:39 PM

Walaupun Notepad tidak dapat menjalankan kod Java secara langsung, ia dapat dicapai dengan menggunakan alat lain: menggunakan pengkompil baris arahan (Javac) untuk menghasilkan fail bytecode (fileName.class). Gunakan Java Interpreter (Java) untuk mentafsir bytecode, laksanakan kod, dan output hasilnya.

Apa itu vscode untuk apa vscode? Apa itu vscode untuk apa vscode? Apr 15, 2025 pm 06:45 PM

VS Kod adalah nama penuh Visual Studio Code, yang merupakan editor kod dan persekitaran pembangunan yang dibangunkan oleh Microsoft. Ia menyokong pelbagai bahasa pengaturcaraan dan menyediakan penonjolan sintaks, penyiapan automatik kod, coretan kod dan arahan pintar untuk meningkatkan kecekapan pembangunan. Melalui ekosistem lanjutan yang kaya, pengguna boleh menambah sambungan kepada keperluan dan bahasa tertentu, seperti debuggers, alat pemformatan kod, dan integrasi Git. VS Kod juga termasuk debugger intuitif yang membantu dengan cepat mencari dan menyelesaikan pepijat dalam kod anda.

Boleh vscode digunakan untuk mac Boleh vscode digunakan untuk mac Apr 15, 2025 pm 07:36 PM

VS Kod boleh didapati di Mac. Ia mempunyai sambungan yang kuat, integrasi git, terminal dan debugger, dan juga menawarkan banyak pilihan persediaan. Walau bagaimanapun, untuk projek yang sangat besar atau pembangunan yang sangat profesional, kod VS mungkin mempunyai prestasi atau batasan fungsi.

Cara menggunakan vscode Cara menggunakan vscode Apr 15, 2025 pm 11:21 PM

Visual Studio Code (VSCode) adalah editor cross-platform, sumber terbuka dan editor kod percuma yang dibangunkan oleh Microsoft. Ia terkenal dengan ringan, skalabilitas dan sokongan untuk pelbagai bahasa pengaturcaraan. Untuk memasang VSCode, sila lawati laman web rasmi untuk memuat turun dan jalankan pemasang. Apabila menggunakan VSCode, anda boleh membuat projek baru, edit kod, kod debug, menavigasi projek, mengembangkan VSCode, dan menguruskan tetapan. VSCode tersedia untuk Windows, MacOS, dan Linux, menyokong pelbagai bahasa pengaturcaraan dan menyediakan pelbagai sambungan melalui pasaran. Kelebihannya termasuk ringan, berskala, sokongan bahasa yang luas, ciri dan versi yang kaya

Apakah tujuan utama Linux? Apakah tujuan utama Linux? Apr 16, 2025 am 12:19 AM

Penggunaan utama Linux termasuk: 1. Sistem Operasi Pelayan, 2. Sistem Terbenam, 3. Linux cemerlang dalam bidang ini, menyediakan kestabilan, keselamatan dan alat pembangunan yang cekap.

Cara memeriksa alamat gudang git Cara memeriksa alamat gudang git Apr 17, 2025 pm 01:54 PM

Untuk melihat alamat repositori Git, lakukan langkah -langkah berikut: 1. Buka baris arahan dan navigasi ke direktori repositori; 2. Jalankan perintah "Git Remote -V"; 3. Lihat nama repositori dalam output dan alamat yang sepadan.

See all articles