Rumah Java javaTutorial Menggunakan Shiro untuk pengesahan dalam pembangunan API Java

Menggunakan Shiro untuk pengesahan dalam pembangunan API Java

Jun 18, 2023 am 11:20 AM
java api shiro

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.

  1. 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>
Salin selepas log masuk
  1. 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.

  1. 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
Salin selepas log masuk

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
Salin selepas log masuk
  1. 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) {
    // 当认证失败时,抛出异常,我们可以根据不同的异常类型做出不同的响应
    // ...
}
Salin selepas log masuk

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.

  1. 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 {
    // 用户没有相应的读取权限,不能查看用户信息
    // ...
}
Salin selepas log masuk

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.

  1. 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!

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)

Topik panas

Tutorial Java
1653
14
Tutorial PHP
1251
29
Tutorial C#
1224
24
Cuti atau kembali dari Java 8 Stream Foreach? Cuti atau kembali dari Java 8 Stream Foreach? Feb 07, 2025 pm 12:09 PM

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: Bahasa utama untuk pembangunan web PHP: Bahasa utama untuk pembangunan web Apr 13, 2025 am 12:08 AM

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 vs Python: Memahami Perbezaan PHP vs Python: Memahami Perbezaan Apr 11, 2025 am 12:15 AM

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 vs Bahasa Lain: Perbandingan PHP vs Bahasa Lain: Perbandingan Apr 13, 2025 am 12:19 AM

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 vs Python: Ciri dan Fungsi Teras PHP vs Python: Ciri dan Fungsi Teras Apr 13, 2025 am 12:16 AM

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.

Program Java untuk mencari kelantangan kapsul Program Java untuk mencari kelantangan kapsul Feb 07, 2025 am 11:37 AM

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

PHP: asas banyak laman web PHP: asas banyak laman web Apr 13, 2025 am 12:07 AM

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.

Impak PHP: Pembangunan Web dan seterusnya Impak PHP: Pembangunan Web dan seterusnya Apr 18, 2025 am 12:10 AM

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

See all articles