


Bagaimana untuk Mengkonfigurasi Berbilang Konfigurasi Keselamatan HTTP dalam Keselamatan Spring untuk Bahagian Aplikasi Berbeza?
Berbilang Konfigurasi Keselamatan HTTP dalam Keselamatan Musim Bunga
Dalam Keselamatan Musim Bunga, anda mungkin menghadapi situasi di mana anda memerlukan halaman log masuk dan konfigurasi keselamatan yang berbeza untuk bahagian permohonan anda. Untuk mencapai matlamat ini, anda boleh memanfaatkan pendekatan MultipleHttpSecurityConfig.
Dalam contoh khusus anda, anda telah mengkonfigurasikan dua kelas bersarang, ProviderSecurity dan ConsumerSecurity, dalam kelas induk beranotasi dengan @EnableWebSecurity. Walaupun konfigurasi keselamatan untuk /admin/** berfungsi seperti yang diharapkan, anda telah memerhatikan bahawa halaman yang dihadkan oleh "/consumer/**" tidak dilindungi seperti yang dimaksudkan.
Analisis
Isu anda timbul daripada fakta bahawa kedua-dua konfigurasi anda membenarkan semua permintaan secara lalai. Ini membenarkan akses kepada semua halaman, tanpa mengira sekatan keselamatan yang ditetapkan. Untuk membetulkan perkara ini, anda perlu mengehadkan akses kepada URL tertentu atau corak permintaan secara eksplisit.
Penyelesaian
Untuk menyelesaikannya, laksanakan langkah berikut:
-
Gunakan kaedah antMatcher dalam konfigurasi ProviderSecurity anda untuk menentukan corak URL yang ia terpakai kepada:
@Configuration @Order(1) public static class ProviderSecurity extends WebSecurityConfigurerAdapter{ @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/", "/home").permitAll() .antMatchers("/admin/login").permitAll() .anyRequest().hasRole("BASE_USER") // Restrict all other URLs .and() ... }
Salin selepas log masuk -
Begitu juga, dalam konfigurasi ConsumerSecurity anda, nyatakan corak URL yang sepatutnya dilindungi:
@Configuration @Order(2) public static class ConsumerSecurity extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http .authorizeRequests() .antMatchers("/consumer/login").permitAll() .anyRequest().hasRole("BASE_USER") // Restrict all other URLs .and() ... }
Salin selepas log masuk
Dengan mengehadkan akses kepada corak URL tertentu, anda boleh menguatkuasakan keselamatan yang dimaksudkan untuk aplikasi anda.
Atas ialah kandungan terperinci Bagaimana untuk Mengkonfigurasi Berbilang Konfigurasi Keselamatan HTTP dalam Keselamatan Spring untuk Bahagian Aplikasi Berbeza?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas











Penyelesaian masalah dan penyelesaian kepada perisian keselamatan syarikat yang menyebabkan beberapa aplikasi tidak berfungsi dengan baik. Banyak syarikat akan menggunakan perisian keselamatan untuk memastikan keselamatan rangkaian dalaman. …

Penyelesaian untuk menukar nama kepada nombor untuk melaksanakan penyortiran dalam banyak senario aplikasi, pengguna mungkin perlu menyusun kumpulan, terutama dalam satu ...

Pemprosesan pemetaan medan dalam dok sistem sering menemui masalah yang sukar ketika melaksanakan sistem dok: bagaimana untuk memetakan medan antara muka sistem dengan berkesan ...

Mula musim bunga menggunakan versi IntelliJideaultimate ...

Penukaran objek dan tatasusunan Java: Perbincangan mendalam tentang risiko dan kaedah penukaran jenis cast yang betul Banyak pemula Java akan menemui penukaran objek ke dalam array ...

Apabila menggunakan Mybatis-Plus atau Rangka Kerja ORM yang lain untuk operasi pangkalan data, sering diperlukan untuk membina syarat pertanyaan berdasarkan nama atribut kelas entiti. Sekiranya anda secara manual setiap kali ...

Penjelasan terperinci mengenai reka bentuk jadual SKU dan SPU di platform e-dagang Artikel ini akan membincangkan isu reka bentuk pangkalan data SKU dan SPU dalam platform e-dagang, terutamanya bagaimana menangani jualan yang ditentukan pengguna ...

Bagaimanakah penyelesaian caching Redis menyedari keperluan senarai kedudukan produk? Semasa proses pembangunan, kita sering perlu menangani keperluan kedudukan, seperti memaparkan ...
