Spring インターセプターの実装原理を調べる
Spring インターセプターの実装メカニズムを明らかにする
はじめに
Web アプリケーションを開発するとき、リクエストがコントローラーに到達する前または後に待機する必要があることがよくあります。何かをしてください。たとえば、ユーザーの認証、ログの記録、例外の処理などです。 Spring フレームワークは、これらの操作を実装するためのインターセプター (インターセプター) を提供しており、インターセプターはリクエストと応答を前処理および後処理できます。
この記事では、Spring インターセプターの実装メカニズムについて詳しく説明します。インターセプターとは何か、どのように機能するかを理解し、具体的なコード例を通じてカスタム インターセプターを実装する方法を示します。
インターセプターの概念
インターセプターは、リクエストの前処理および後処理に使用される Spring フレームワークのメカニズムです。これはサーブレットのフィルターに似ていますが、フィルターとは異なり、インターセプターはメソッド レベルに基づいています。指定されたコントローラーのメソッドをインターセプトし、メソッドの実行前後にカスタム ロジックを実行できます。インターセプターは、ビジネス ロジックとは関係のない一般的な処理を実装し、コードの再利用性と保守性を向上させるのに役立ちます。
インターセプターの仕組み
インターセプターは、AOP (アスペクト指向プログラミング) を通じて実装されます。 Spring インターセプターは、preHandle、postHandle、afterCompletion の 3 つのメソッドを定義する HandlerInterceptor インターフェイスに基づいています。具体的なワークフローは次のとおりです。
- クライアントが DispatcherServlet にリクエストを送信すると、DispatcherServlet はリクエストされた URL に基づいて対応する HandlerMapping を検索し、対応する HandlerExecutionChain を取得します。
- HandlerExecutionChain には、一連の HandlerInterceptor が含まれています。
-
DispatcherServlet は、各インターセプターの preHandle メソッドを順番に呼び出し、メソッドの戻り値をチェックします。
- true が返された場合、リクエストは処理を続行し、次のインターセプターの preHandle メソッドに入ります。
- false が返された場合、リクエストはここで中断され、クライアントに返されます。
- すべてのインターセプタ preHandle メソッドが true を返すと、DispatcherServlet は HandlerExecutionChain の Handler オブジェクトの handleRequest メソッドを呼び出します。
- HandlerExecutionChain の Handler オブジェクトはビジネス ロジックを実行し、ModelAndView を返します。
- DispatcherServlet は、各インターセプターの postHandle メソッドを順番に呼び出し、ModelAndView を渡します。
- インターセプターの postHandle メソッドは、ModelAndView を変更および拡張できます。
- DispatcherServlet は、ビューの解析とレンダリングのために ModelAndView を ViewResolver に渡します。
- ビューがレンダリングされると、DispatcherServlet は各インターセプターの afterCompletion メソッドを順番に呼び出して、一部のリソースをさらにクリーンアップします。
カスタム インターセプターの実装
以下では、特定の例を使用してカスタム インターセプターを実装する方法を示します。
public class MyInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { // 在方法执行之前进行逻辑处理 System.out.println("拦截器preHandle方法执行"); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { // 在方法执行之后进行逻辑处理 System.out.println("拦截器postHandle方法执行"); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { // 在视图渲染完成后进行逻辑处理 System.out.println("拦截器afterCompletion方法执行"); } }
上記のコードでは、HandlerInterceptor インターフェイスを実装し、その 3 つのメソッドを書き直しました。 preHandle メソッドでは前処理を実行でき、postHandle メソッドでは ModelAndView を変更および拡張でき、afterCompletion メソッドではリソースのクリーンアップ操作を実行できます。
次に、カスタム インターセプターを Spring コンテナーに構成する必要があります。これは、XML 構成または注釈を通じて実現できます。
XML 設定方法
Spring 設定ファイルに次の設定を追加します。
<mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**" /> <mvc:exclude-mapping path="/login" /> <bean class="com.example.MyInterceptor" /> </mvc:interceptor> </mvc:interceptors>
上記の設定では、<mvc:interceptor>
タグを使用してインターセプターを定義し、<mvc:mapping>
タグを通じてインターセプトする URL パスを指定します。 <mvc:exclude-mapping>
タグを使用して、インターセプトする必要のない一部の URL パスを除外します。
アノテーションを使用したインターセプターの構成
@Component
アノテーションをインターセプター クラスに追加し、@Order
アノテーションを使用して実行順序を指定しますインターセプターの。
@Component @Order(1) public class MyInterceptor implements HandlerInterceptor { // 省略代码 }
Spring の構成クラスに次の構成を追加します:
@Configuration public class WebConfig implements WebMvcConfigurer { @Autowired private MyInterceptor myInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(myInterceptor).addPathPatterns("/**").excludePathPatterns("/login"); } }
上記の構成では、WebMvcConfigurer インターフェイスを実装し、レジストリ内の addInterceptors メソッドを書き換えることによって、インターセプターをインターセプターに追加します。
結論
この記事を通じて、Spring インターセプターの概念と動作原理を理解し、特定のコード例を通じてカスタム インターセプターを実装する方法を示しました。インターセプターは Spring フレームワークの非常に重要な機能であり、一般的な処理ロジックを実装し、コードの再利用性と保守性を向上させるのに役立ちます。この記事が Spring インターセプターの理解に役立つことを願っています。
以上がSpring インターセプターの実装原理を調べるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









2023年、AI技術が注目を集め、プログラミング分野を中心にさまざまな業界に大きな影響を与えています。 AI テクノロジーの重要性に対する人々の認識はますます高まっており、Spring コミュニティも例外ではありません。 GenAI (汎用人工知能) テクノロジーの継続的な進歩に伴い、AI 機能を備えたアプリケーションの作成を簡素化することが重要かつ緊急になっています。このような背景から、AI 機能アプリケーションの開発プロセスを簡素化し、シンプルかつ直観的にし、不必要な複雑さを回避することを目的とした「SpringAI」が登場しました。 「SpringAI」により、開発者はAI機能を搭載したアプリケーションをより簡単に構築でき、使いやすく、操作しやすくなります。

Spring+AI は業界リーダーとして、強力で柔軟な API と高度な機能を通じてさまざまな業界に最先端のソリューションを提供します。このトピックでは、さまざまな分野での Spring+AI の応用例を詳しく掘り下げ、Spring+AI がどのように特定のニーズを満たし、目標を達成し、これらの教訓をより広範囲のアプリケーションに拡張するかを示します。このトピックが Spring+AI の無限の可能性をより深く理解し、活用するきっかけになれば幸いです。 Spring フレームワークはソフトウェア開発の分野で 20 年以上の歴史があり、Spring Boot 1.0 バージョンがリリースされてから 10 年が経過しました。今、その春に異論を唱える人はいない

Spring プログラムによるトランザクションを実装する方法: 1. TransactionTemplate を使用する; 2. TransactionCallback および TransactionCallbackWithoutResult を使用する; 3. Transactional アノテーションを使用する; 4. TransactionTemplate を @Transactional と組み合わせて使用する; 5. トランザクション マネージャーをカスタマイズする。

インターセプターは、メソッド実行の前後にカスタム動作を挿入できるようにする設計パターンで、Go では net/http ミドルウェアを通じて実装できます。スケーラビリティ、再利用性、テスト容易性などの利点があり、認証、認可、キャッシュ、ロギング、カスタム エラー処理などのシナリオで使用できます。

テクノロジーの更新と反復により、Java5.0 はアノテーションをサポートし始めました。 Java の主要なフレームワークである Spring は、バージョン 2.5 に更新されて以来、徐々に XML 構成を放棄し始めており、Spring フレームワークを制御するために使用されるアノテーションが増えています。

Spring でトランザクション分離レベルを設定する方法: 1. @Transactional アノテーションを使用します; 2. Spring 構成ファイルに設定します; 3. PlatformTransactionManager を使用します; 4. Java 構成クラスに設定します。詳細な導入方法: 1. @Transactional アノテーションを使用し、トランザクション管理が必要なクラスまたはメソッドに @Transactional アノテーションを追加し、属性に分離レベルを設定します。 2. Spring の設定ファイルなどで

Spring は、Java 開発を簡素化し、強化するための多くのアノテーションを提供するオープンソース フレームワークです。この記事では、一般的に使用される Spring アノテーションについて詳しく説明し、具体的なコード例を示します。 @Autowired: Autowired @Autowired アノテーションを使用して、Spring コンテナーに Bean を自動的に接続できます。依存関係が必要な場合に @Autowired アノテーションを使用すると、Spring はコンテナー内で一致する Bean を見つけて自動的に注入します。サンプルコードは次のとおりです。

JUnit は Spring プロジェクトで広く使用されている Java 単体テスト フレームワークであり、次の手順で適用できます。 JUnit 依存関係を追加します。 org.junit.jupiterjunit-jupiter5.8.1test テスト ケースを作成します。 @ExtendWith(SpringExtension.class) を使用して拡張機能を有効にします。 @Autowired を使用して Bean を注入し、@BeforeEach と @AfterEach を使用して準備とクリーンアップを行い、テスト メソッドを @Test でマークします。
