Pernyataan Masalah
Untuk mengakses Butiran Pengguna pengguna yang sedang log masuk pelaksanaan dalam pengawal dalam aplikasi Spring MVC, pembangun biasanya menggunakan penyelesaian yang melibatkan mendapatkan semula objek Prinsipal dan menghantarnya kepada jenis yang dikehendaki. Walaupun pendekatan ini berfungsi, ia memperkenalkan kerumitan dan kekacauan yang tidak perlu dalam pengawal.
Penyelesaian Elegan dengan @AuthenticationPrincipal
Nasib baik, Spring Security menyediakan penyelesaian yang lebih diperkemas untuk senario ini melalui penggunaan anotasi. Untuk versi Spring Security 3.2 dan ke atas, pembangun boleh menggunakan anotasi @AuthenticationPrincipal dalam pengawal mereka untuk mendapatkan semula pelaksanaan UserDetails.
Pelaksanaan Menggunakan @AuthenticationPrincipal
Untuk menggunakan ini anotasi, anda boleh mengubah suai kaedah pengawal anda seperti berikut:
<code class="java">public ModelAndView someRequestHandler(@AuthenticationPrincipal User activeUser) { // ... }</code>
Penyelesaian Alternatif dengan HandlerMethodArgumentResolver
Jika anda menggunakan Spring 3.1 atau lebih awal, atau jika anda memerlukan lebih banyak lagi fleksibiliti, anda boleh melaksanakan WebArgumentResolver atau HandlerMethodArgumentResolver tersuai untuk mencapai kefungsian ini.
WebArgumentResolver Approach
Untuk WebArgumentResolver, anda boleh mencipta kelas yang melaksanakan antara muka berikut:
<code class="java">public class CurrentUserWebArgumentResolver implements WebArgumentResolver{ // Implement the resolveArgument method as detailed in the answer }</code>
Pendekatan HandlerMethodArgumentResolver
Untuk HandlerMethodArgumentResolver, anda boleh mencipta kelas yang melaksanakan antara muka berikut:
<code class="java">public class CurrentUserHandlerMethodArgumentResolver implements HandlerMethodArgumentResolver { // Implement the supportsParameter and resolveArgument methods as detailed in the answer }</code>
>
Selepas melaksanakan penyelesai hujah tersuai anda, anda perlu mengkonfigurasinya dalam fail konfigurasi Spring anda:<code class="xml"><bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" id="applicationConversionService"> <property name="customArgumentResolver"> <bean class="CurrentUserWebArgumentResolver"/> </property> </bean></code>
Spring Security 3.2 dan Penyelesaian Kemudian
Untuk Spring Security 3.2 dan lebih baru, penyelesaian terbina dalam wujud: anotasi @AuthenticationPrincipal dan AuthenticationPrincipalArgumentResolver. Hanya tambah anotasi dan penyelesai hujah pada konfigurasi anda:Atas ialah kandungan terperinci Bagaimana untuk Mudah Mengakses Butiran Pengguna Aktif dalam Spring MVC?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!