cari
RumahJavajavaTutorialMenggunakan 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.

  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>
  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

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

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

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
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
Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?Mar 17, 2025 pm 05:46 PM

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Mar 17, 2025 pm 05:45 PM

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?Mar 17, 2025 pm 05:44 PM

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?Mar 17, 2025 pm 05:43 PM

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?Mar 17, 2025 pm 05:35 PM

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai

See all articles

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan