Rumah Operasi dan penyelenggaraan Nginx Konfigurasi kawalan akses berdasarkan pengepala permintaan dalam proksi terbalik Nginx

Konfigurasi kawalan akses berdasarkan pengepala permintaan dalam proksi terbalik Nginx

Jun 09, 2023 pm 11:40 PM
nginx proksi terbalik Kawalan capaian.

Dengan perkembangan berterusan perniagaan Internet, kaedah penggunaan pelbagai aplikasi web juga sentiasa dikemas kini. Antaranya, proksi terbalik digunakan secara meluas untuk meningkatkan prestasi dan keselamatan laman web. Sebagai pelayan proksi songsang berprestasi tinggi, Nginx mempunyai kaedah konfigurasi yang fleksibel dan boleh melaksanakan kawalan akses yang lebih terperinci berdasarkan pengepala permintaan.

Dalam aplikasi praktikal, kami selalunya perlu mengehadkan kebenaran akses berdasarkan pengguna atau pelanggan yang berbeza. Contohnya, aplikasi perlu dihadkan kepada pekerja dalam syarikat, atau hanya pengguna yang membayar boleh mengakses ciri lanjutan tertentu. Pada masa ini, kawalan akses berdasarkan pengepala permintaan menjadi sangat penting.

Nginx menyediakan banyak modul dan arahan untuk mengawal akses berdasarkan atribut berbeza pengepala permintaan. Di bawah, kami akan memperkenalkan beberapa kaedah konfigurasi yang biasa digunakan.

  1. Pengepala Ejen Pengguna

Pengepala Ejen Pengguna boleh digunakan untuk mengenal pasti jenis klien, seperti penyemak imbas, peranti mudah alih, dsb. Kami boleh menyekat akses kepada pelanggan tertentu berdasarkan pengepala Agen-Pengguna. Contohnya, konfigurasi berikut boleh menafikan akses kepada semua labah-labah enjin carian yang Ejen Penggunanya ialah "Baiduspider":

if ($http_user_agent ~* "^baiduspider") {
    return 403;
}
Salin selepas log masuk
  1. Pengepala perujuk

Pengepala perujuk digunakan untuk mengenal pasti halaman sumber permintaan . Kami boleh menyekat akses ke halaman mana permintaan itu berasal berdasarkan pengepala Perujuk. Sebagai contoh, konfigurasi berikut boleh menolak semua permintaan yang Perujuknya bukan daripada "www.example.com":

if ($http_referer !~* "^https?://www.example.com") {
    return 403;
}
Salin selepas log masuk
  1. Pengepala kuki

Pengepala kuki mengandungi yang terakhir klien permintaan Nilai kuki yang ditetapkan pada masa itu. Kami boleh menentukan sama ada pengguna mempunyai kebenaran khusus berdasarkan pengepala Kuki. Sebagai contoh, konfigurasi berikut hanya boleh membenarkan akses kepada pengguna dengan kuki "vip=true":

if ($http_cookie !~* "vip=true") {
    return 403;
}
Salin selepas log masuk
  1. Pengepala kebenaran

Pengepala kebenaran digunakan untuk mengandungi pengesahan pengguna maklumat, Seperti pengesahan asas (Pengesahan Asas HTTP). Kami boleh menyekat akses kepada pengguna tertentu berdasarkan pengepala Kebenaran. Sebagai contoh, konfigurasi berikut boleh menafikan akses kepada pengguna dengan nama pengguna "admin":

if ($http_authorization ~* "^Basics+.+:admin:") {
    return 403;
}
Salin selepas log masuk

Perlu diingat bahawa arahan Nginx's if akan dilaksanakan dalam setiap permintaan, yang akan membawa overhed prestasi tertentu. Jika terdapat sejumlah besar arahan if, ia boleh menjejaskan prestasi pelayan proksi terbalik. Oleh itu, kita harus mengelakkan penyalahgunaan jika arahan sebanyak mungkin. Jika anda mempunyai keperluan kawalan akses yang kompleks, anda boleh mempertimbangkan untuk menggunakan skrip Lua untuk melaksanakannya.

Secara amnya, konfigurasi kawalan akses berasaskan pengepala permintaan adalah bahagian yang sangat penting dalam proksi terbalik Nginx. Melalui konfigurasi yang munasabah, kawalan capaian yang lebih halus boleh dicapai dan keselamatan dan kestabilan aplikasi web boleh dipertingkatkan.

Atas ialah kandungan terperinci Konfigurasi kawalan akses berdasarkan pengepala permintaan dalam proksi terbalik Nginx. 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)

Cara mengkonfigurasi nama domain pelayan awan di nginx Cara mengkonfigurasi nama domain pelayan awan di nginx Apr 14, 2025 pm 12:18 PM

Cara mengkonfigurasi nama domain Nginx pada pelayan awan: Buat rekod yang menunjuk ke alamat IP awam pelayan awan. Tambah blok hos maya dalam fail konfigurasi Nginx, menyatakan port pendengaran, nama domain, dan direktori akar laman web. Mulakan semula nginx untuk memohon perubahan. Akses konfigurasi ujian nama domain. Nota Lain: Pasang sijil SSL untuk membolehkan HTTPS, pastikan firewall membenarkan trafik port 80, dan tunggu resolusi DNS berkuatkuasa.

Cara memeriksa nama bekas Docker Cara memeriksa nama bekas Docker Apr 15, 2025 pm 12:21 PM

Anda boleh menanyakan nama kontena Docker dengan mengikuti langkah -langkah: Senaraikan semua bekas (Docker PS). Tapis senarai kontena (menggunakan arahan grep). Mendapat nama kontena (terletak di lajur "Nama").

Cara memeriksa sama ada nginx dimulakan Cara memeriksa sama ada nginx dimulakan Apr 14, 2025 pm 01:03 PM

Bagaimana untuk mengesahkan sama ada nginx dimulakan: 1. Gunakan baris arahan: status sistem sistem nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. Periksa sama ada port 80 dibuka; 3. Semak mesej permulaan Nginx dalam log sistem; 4. Gunakan alat pihak ketiga, seperti Nagios, Zabbix, dan Icinga.

Cara Mengkonfigurasi Nginx di Windows Cara Mengkonfigurasi Nginx di Windows Apr 14, 2025 pm 12:57 PM

Bagaimana cara mengkonfigurasi nginx di Windows? Pasang Nginx dan buat konfigurasi hos maya. Ubah suai fail konfigurasi utama dan sertakan konfigurasi hos maya. Mulakan atau Muat semula Nginx. Uji konfigurasi dan lihat laman web. Selektif membolehkan SSL dan mengkonfigurasi sijil SSL. Selektif tetapkan firewall untuk membolehkan trafik port 80 dan 443.

Cara memeriksa versi nginx Cara memeriksa versi nginx Apr 14, 2025 am 11:57 AM

Kaedah yang boleh menanyakan versi nginx adalah: gunakan perintah nginx -v; Lihat arahan versi dalam fail nginx.conf; Buka halaman ralat Nginx dan lihat tajuk halaman.

Cara Memulakan Bekas oleh Docker Cara Memulakan Bekas oleh Docker Apr 15, 2025 pm 12:27 PM

Docker Container Startup Langkah: Tarik Imej Bekas: Run "Docker Pull [Mirror Name]". Buat bekas: Gunakan "Docker Buat [Pilihan] [Nama Mirror] [Perintah dan Parameter]". Mulakan bekas: Jalankan "Docker Start [Nama Container atau ID]". Semak Status Kontena: Sahkan bahawa bekas sedang berjalan dengan "Docker PS".

Cara memulakan pelayan nginx Cara memulakan pelayan nginx Apr 14, 2025 pm 12:27 PM

Memulakan pelayan Nginx memerlukan langkah-langkah yang berbeza mengikut sistem operasi yang berbeza: Sistem Linux/Unix: Pasang pakej Nginx (contohnya, menggunakan apt-get atau yum). Gunakan SystemCTL untuk memulakan perkhidmatan Nginx (contohnya, SUDO SystemCTL Mula Nginx). Sistem Windows: Muat turun dan pasang fail binari Windows. Mula Nginx menggunakan nginx.exe executable (contohnya, nginx.exe -c conf \ nginx.conf). Tidak kira sistem operasi yang anda gunakan, anda boleh mengakses IP pelayan

Cara membuat bekas untuk Docker Cara membuat bekas untuk Docker Apr 15, 2025 pm 12:18 PM

Buat bekas di Docker: 1. Tarik Imej: Docker Pull [Nama Cermin] 2. Buat bekas: Docker Run [Options] [Mirror Name] [Command] 3. Mulailah bekas: Docker Start [Nama Container]

See all articles