@RequestParam および @PathVariable を使用した特殊文字の処理
Web 開発では、リクエスト パラメーターとパス変数での特殊文字の処理は非常に重要です。 Spring Framework の @RequestParam および @PathVariable アノテーションは、これらの文字を管理するための異なるアプローチを提供します。
@PathVariable
このアノテーションは、URI プレースホルダーをメソッド パラメーターにバインドします。特殊文字はパス変数値の一部として扱われます。たとえば、URL「/user/1234/invoices」では、プラス記号 ( ) はリテラル文字を表します。
@RequestParam
対照的に、@RequestParamクエリパラメータをメソッドパラメータにバインドします。通常、特殊文字はデコードされ、スペースとして解釈されます。たとえば、URL「/user/1234/invoices?date=12-05-2013」では、プラス記号 ( ) はスペースとしてデコードされます。
リクエスト パラメーターとパスの役割Variables
コントローラー メソッドでの使用法
ユーザーの請求書を処理するコントローラー メソッドを考えてみましょう。
@RequestMapping(value="/user/{userId}/invoices", method = RequestMethod.GET) public List<Invoice> listUsersInvoices( @PathVariable("userId") int user, @RequestParam(value = "date", required = false) Date dateOrNull) { ... }
ここでは、 @PathVariable はパス変数「userId」をパラメータ「user」にバインドします。一方、@RequestParam はパス変数「userId」をパラメータ「user」にバインドします。クエリパラメータ「date」を「dateOrNull」に取得します。
注: Spring 4.3.3 以降、パス変数もオプションとして宣言できますが、潜在的な URL パス階層に注意してください。変更とマッピングの競合。
以上がSpring での特殊文字の処理において、`@RequestParam` と `@PathVariable` はどのように異なりますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。