Menggunakan Shiro untuk pengesahan dalam pembangunan API Java
Dalam pembangunan Java, keselamatan aplikasi adalah penting. Shiro ialah rangka kerja keselamatan Java yang berkuasa dan mudah digunakan yang boleh digunakan untuk melaksanakan fungsi keselamatan seperti pengesahan, kebenaran, penyulitan dan pengurusan sesi. Dalam artikel ini, kami akan memperkenalkan cara menggunakan Shiro untuk pengesahan dalam pembangunan API Java.
- Mula
Sebelum menggunakan Shiro, kita perlu membuat beberapa tetapan asas. Kita boleh menggunakan Maven untuk menambah kebergantungan Shiro. Tambahkan kod berikut dalam pom.xml projek:
<dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-core</artifactId> <version>1.7.1</version> </dependency>
- Konsep asas Shiro
Apabila menggunakan Shiro, kita perlu memahami beberapa konsep asas. Berikut ialah beberapa konsep penting:
Pengesahan: Pengesahan ialah proses mengesahkan identiti pengguna. Di Shiro, kami boleh mengesahkan melalui nama pengguna dan kata laluan.
Keizinan: Keizinan ialah proses mengesahkan bahawa pengguna mempunyai kebenaran yang mencukupi untuk melaksanakan operasi. Dalam Shiro, kita boleh menggunakan peranan dan kebenaran untuk kebenaran.
Pengurusan sesi: Sesi merujuk kepada proses interaksi dengan pelayan Ia boleh menjadi proses permintaan dan tindak balas, atau sejumlah besar proses interaksi pada pelayan. Shiro menyediakan fungsi pengurusan sesi untuk mengurus kitaran hayat sesi pengguna.
Penyulitan: Penyulitan merujuk kepada penyulitan kata laluan pengguna dan maklumat sensitif lain. Shiro menyediakan pelbagai algoritma pencincangan dan penyulitan untuk menyulitkan maklumat pengguna dengan mudah.
- Mengkonfigurasi Shiro
Apabila menggunakan Shiro, kita perlu mengkonfigurasi dasar keselamatan Shiro terlebih dahulu. Ini boleh dicapai dengan menetapkan perkara berikut dalam fail konfigurasi Shiro:
securityManager.realms = $myRealm securityManager.sessionManager = $sessionManager sessionManager.globalSessionTimeout = 86400000
Dalam konfigurasi di atas, kami menggunakan myRealm sebagai dasar keselamatan Shiro. Kami juga menetapkan tamat masa sesi global kepada satu hari (24 jam).
Selain itu, kami juga perlu mengisytiharkan komponen lain dalam fail konfigurasi Shiro, seperti AuthenticatingRealm, CredentialsMatcher, dsb. Berikut ialah contoh fail konfigurasi:
[main] # Shiro提供的默认的会话管理器实现 sessionManager = org.apache.shiro.web.session.mgt.DefaultWebSessionManager # 自定义的会话DAO,实现了会话保存、更新、删除 sessionDAO = org.apache.shiro.session.mgt.eis.EnterpriseCacheSessionDAO securityManager.sessionManager = $sessionManager securityManager.sessionManager.sessionDAO = $sessionDAO # 使用自定义的Realm实现 myRealm = com.example.MyRealm securityManager.realms = $myRealm # 加密配置 credentialsMatcher = org.apache.shiro.authc.credential.Sha256CredentialsMatcher # 密码加密的次数 credentialsMatcher.hashIterations = 1024 myRealm.credentialsMatcher = $credentialsMatcher
- Sahkan Pengguna
Selepas mengkonfigurasi Shiro, kami kini boleh mula menulis kod untuk mengesahkan pengguna. Kita boleh menggunakan objek UsernamePasswordToken yang disediakan oleh Shiro untuk mengesahkan pengguna. Berikut ialah contoh kod:
// 在应用程序中创建一个SecurityUtils实例 SecurityUtils securityUtils = new SecurityUtils(); // 创建一个Subject对象,表示当前用户的身份 Subject currentUser = securityUtils.getSubject(); // 创建一个UsernamePasswordToken对象,表示用户输入的用户名和密码 UsernamePasswordToken token = new UsernamePasswordToken("username", "password"); try { // 调用Subject的login方法进行认证 currentUser.login(token); // 认证成功后,我们可以执行必要的操作,如重定向到受保护的页面 // ... } catch (UnknownAccountException | IncorrectCredentialsException e) { // 当认证失败时,抛出异常,我们可以根据不同的异常类型做出不同的响应 // ... }
Dalam kod di atas, kami mencipta objek Subjek yang mewakili identiti pengguna semasa. Kami kemudian mencipta objek UsernamePasswordToken yang mewakili nama pengguna dan kata laluan yang dimasukkan oleh pengguna. Akhir sekali, kami memanggil kaedah log masuk Subjek untuk mengesahkan pengguna. Jika pengesahan pengguna gagal, pengecualian yang sesuai akan dilemparkan. Jika pengesahan pengguna berjaya, mereka boleh meneruskan operasi lain.
- Melaksanakan kebenaran
Selepas mengesahkan pengguna, kami boleh menggunakan fungsi kebenaran Shiro untuk mengawal akses pengguna kepada sumber sistem. Keizinan boleh dicapai melalui peranan dan kebenaran. Berikut ialah contoh kod:
// 在应用程序中创建一个SecurityUtils实例 SecurityUtils securityUtils = new SecurityUtils(); // 创建一个Subject对象,表示当前用户的身份 Subject currentUser = securityUtils.getSubject(); // 检查用户是否具有角色 if (currentUser.hasRole("admin")) { // 用户具有管理员角色,可以执行管理员特权操作 // ... } else { // 用户不是管理员,不能执行管理员特权操作 // ... } // 检查用户是否具有权限 if (currentUser.isPermitted("user:read")) { // 用户具有读取用户信息的权限,可以查看用户信息 // ... } else { // 用户没有相应的读取权限,不能查看用户信息 // ... }
Dalam kod di atas, kami menggunakan kaedah hasRole untuk menentukan sama ada pengguna mempunyai peranan. Kami menggunakan kaedah isPermitted untuk menentukan sama ada pengguna mempunyai kebenaran. Jika pengguna mempunyai peranan atau kebenaran yang sepadan, dia boleh melakukan operasi yang sepadan.
- Kesimpulan
Menggunakan Shiro untuk pengesahan boleh menjadikan pembangunan API Java lebih selamat. Shiro menyediakan fungsi pengesahan, kebenaran, penyulitan dan pengurusan sesi. Kami boleh menggunakan Shiro untuk mengesahkan pengguna, membenarkan pengguna mengakses sumber sistem dan menyulitkan maklumat pengguna. Dengan menggunakan Shiro, kami boleh meningkatkan keselamatan dan kebolehpercayaan aplikasi kami dengan mudah.
Atas ialah kandungan terperinci Menggunakan Shiro untuk pengesahan dalam pembangunan API Java. 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











Java 8 memperkenalkan API Stream, menyediakan cara yang kuat dan ekspresif untuk memproses koleksi data. Walau bagaimanapun, soalan biasa apabila menggunakan aliran adalah: bagaimana untuk memecahkan atau kembali dari operasi foreach? Gelung tradisional membolehkan gangguan awal atau pulangan, tetapi kaedah Foreach Stream tidak menyokong secara langsung kaedah ini. Artikel ini akan menerangkan sebab -sebab dan meneroka kaedah alternatif untuk melaksanakan penamatan pramatang dalam sistem pemprosesan aliran. Bacaan Lanjut: Penambahbaikan API Java Stream Memahami aliran aliran Kaedah Foreach adalah operasi terminal yang melakukan satu operasi pada setiap elemen dalam aliran. Niat reka bentuknya adalah

PHP adalah bahasa skrip yang digunakan secara meluas di sisi pelayan, terutamanya sesuai untuk pembangunan web. 1.PHP boleh membenamkan HTML, memproses permintaan dan respons HTTP, dan menyokong pelbagai pangkalan data. 2.PHP digunakan untuk menjana kandungan web dinamik, data borang proses, pangkalan data akses, dan lain -lain, dengan sokongan komuniti yang kuat dan sumber sumber terbuka. 3. PHP adalah bahasa yang ditafsirkan, dan proses pelaksanaan termasuk analisis leksikal, analisis tatabahasa, penyusunan dan pelaksanaan. 4.Php boleh digabungkan dengan MySQL untuk aplikasi lanjutan seperti sistem pendaftaran pengguna. 5. Apabila debugging php, anda boleh menggunakan fungsi seperti error_reporting () dan var_dump (). 6. Mengoptimumkan kod PHP untuk menggunakan mekanisme caching, mengoptimumkan pertanyaan pangkalan data dan menggunakan fungsi terbina dalam. 7

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

PHP sesuai untuk pembangunan web, terutamanya dalam pembangunan pesat dan memproses kandungan dinamik, tetapi tidak baik pada sains data dan aplikasi peringkat perusahaan. Berbanding dengan Python, PHP mempunyai lebih banyak kelebihan dalam pembangunan web, tetapi tidak sebaik python dalam bidang sains data; Berbanding dengan Java, PHP melakukan lebih buruk dalam aplikasi peringkat perusahaan, tetapi lebih fleksibel dalam pembangunan web; Berbanding dengan JavaScript, PHP lebih ringkas dalam pembangunan back-end, tetapi tidak sebaik JavaScript dalam pembangunan front-end.

PHP dan Python masing -masing mempunyai kelebihan sendiri dan sesuai untuk senario yang berbeza. 1.PHP sesuai untuk pembangunan web dan menyediakan pelayan web terbina dalam dan perpustakaan fungsi yang kaya. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan standard yang kuat. Apabila memilih, ia harus diputuskan berdasarkan keperluan projek.

Kapsul adalah angka geometri tiga dimensi, terdiri daripada silinder dan hemisfera di kedua-dua hujungnya. Jumlah kapsul boleh dikira dengan menambahkan isipadu silinder dan jumlah hemisfera di kedua -dua hujungnya. Tutorial ini akan membincangkan cara mengira jumlah kapsul yang diberikan dalam Java menggunakan kaedah yang berbeza. Formula volum kapsul Formula untuk jumlah kapsul adalah seperti berikut: Kelantangan kapsul = isipadu isipadu silinder Dua jumlah hemisfera dalam, R: Radius hemisfera. H: Ketinggian silinder (tidak termasuk hemisfera). Contoh 1 masukkan Jejari = 5 unit Ketinggian = 10 unit Output Jilid = 1570.8 Unit padu menjelaskan Kirakan kelantangan menggunakan formula: Kelantangan = π × r2 × h (4

Sebab mengapa PHP adalah timbunan teknologi pilihan untuk banyak laman web termasuk kemudahan penggunaannya, sokongan komuniti yang kuat, dan penggunaan yang meluas. 1) Mudah dipelajari dan digunakan, sesuai untuk pemula. 2) Mempunyai komuniti pemaju yang besar dan sumber yang kaya. 3) Digunakan secara meluas dalam platform WordPress, Drupal dan lain -lain. 4) Mengintegrasikan dengan ketat dengan pelayan web untuk memudahkan penggunaan pembangunan.

Phphassignificantelympactedwebdevelopmentandextendsbeyondit.1) itpowersmajorplatformslikeworderpressandexcelsindatabaseIntions.2) php'SadaptabilityAldoStoScaleforlargeapplicationFrameworksLikelara.3)
