1. リクエスト パラメータの取得
クライアント リクエスト パラメータの形式は次のとおりです: name=value&name=value... サーバーはリクエストされたパラメータを取得する必要があります。 SpringMVC は次のタイプのパラメーターを受け取ることができます:
1) 基本型パラメーター:
コントローラー内のビジネス メソッドのパラメーター名は、以下と一致している必要があります。リクエストパラメータの名前。値は自動的にマッピングされ、照合されます。
//http://localhost:8080/project/quick9?username=zhangsan&age=12 @RequestMapping("/quick9") @ResponseBody public void quickMethod9(String username,int age) throws IOException { System.out.println(username); System.out.println(age); }
2) POJO 型パラメーター:
コントローラー内のビジネス メソッドの POJO パラメーターの属性名はリクエスト パラメーターの名前と一致しており、パラメーター値は自動的に設定されます。マッピングされ、一致しました。
//http://localhost:8080/itheima_springmvc1/quick9?username=zhangsan&age=12 public class User { private String username; private int age; getter/setter… } @RequestMapping("/quick10") @ResponseBody public void quickMethod10(User user) throws IOException { System.out.println(user); }
3) 配列型パラメーター
コントローラー内のビジネス メソッド配列の名前はリクエスト パラメーターの名前と一致しており、パラメーター値は自動的にマッピングおよび照合されます。 。
//http://localhost:8080/project/quick11?strs=111&strs=222&strs=333 @RequestMapping("/quick11") @ResponseBody public void quickMethod11(String[] strs) throws IOException { System.out.println(Arrays.asList(strs)); }
4) コレクション型パラメータ
コレクション パラメータを取得するときは、コレクション パラメータを POJO にラップする必要があります。
<form action="${pageContext.request.contextPath}/quick12" method="post"> <input type="text" name="userList[0].username"><br> <input type="text" name="userList[0].age"><br> <input type="text" name="userList[1].username"><br> <input type="text" name="userList[1].age"><br> <input type="submit" value="提交"><br> </form>
@RequestMapping("/quick12") @ResponseBody public void quickMethod12(Vo vo) throws IOException { System.out.println(vo.getUserList()); }
ajax を使用して送信する場合、contentType を json として指定し、メソッド パラメーターの位置で @RequestBody を使用すると、パッケージ化に POJO を使用せずにコレクション データを直接受け取ることができます。
<script> //模拟数据 var userList = new Array(); userList.push({username: "zhangsan",age: "20"}); userList.push({username: "lisi",age: "20"}); $.ajax({ type: "POST", url: "/itheima_springmvc1/quick13", data: JSON.stringify(userList), contentType : 'application/json;charset=utf-8' }); </script>
@RequestMapping("/quick13") @ResponseBody public void quickMethod13(@RequestBody List<User> userList) throws IOException { System.out.println(userList); }
注: Google 開発者ツールのパケット キャプチャにより、jquery ファイルが読み込まれていないことが判明しました。その理由は、SpringMVC フロントエンド コントローラー DispatcherServlet の URL パターンが / で構成されているためです。すべてのリソースがフィルタリングされることを意味します。次の 2 つの方法で、解放された静的リソースを指定できます: • spring-mvc.xml 設定ファイルで解放されたリソースを指定します。
<mvc:resources mapping="/js/**" location="/js/"/>
• または、
2. リクエスト文字化けの問題
POST リクエストを行うとデータが文字化けするので、web.xml でフィルタを設定することができますエンコーディングをフィルタリングします。
<!--资源过滤器--> <filter> <filter-name>CharacterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
要求されたパラメーター名がコントローラーのビジネス メソッドのパラメーター名と一致しない場合は、 @RequestParam アノテーションを使用してバインディングを表示する必要があります。
<form action="${pageContext.request.contextPath}/quick14" method="post"> <input type="text" name="name"><br> <input type="submit" value="提交"><br> </form>
3. パラメータ バインディング アノテーション @RequestParam
アノテーション @RequestParam には、使用できる次のパラメータもあります:
value : | リクエスト パラメータ名 |
必須: | 指定されたリクエスト パラメータを含める必要があるかどうか。そのようなパラメータがない場合、デフォルトは true です。送信時にエラーが報告されます |
defaultValue: | リクエストパラメータが指定されていない場合、指定されたデフォルト値が割り当てに使用されます |
リソースを取得 | |
リソースを削除 | PUT: |
POST: | |
#例: |
/user/1 のユーザーを取得 DELETE: | |
/user/1 を削除 PUT: | |
user を更新id = 1 POST : | |
上記 URL の address/user/1 は取得するリクエストパラメータで、プレースホルダは取得できます。 SpringMVCで使用されるパラメータバインディングを実行します。アドレス /user/1 は /user/{id} として記述でき、プレースホルダー {id} は値 1 に対応します。ビジネス メソッドでは、@PathVariable アノテーションを使用してプレースホルダーの一致を取得できます。 |
SpringMVC は、クライアントによって送信された文字列を int 型に変換するなど、一般的に使用されるいくつかの型コンバーターをデフォルトで提供していますが、パラメータ設定。
ただし、すべてのデータ型にコンバーターが提供されているわけではありません。コンバーターが提供されていない場合は、コンバーターをカスタマイズする必要があります。たとえば、日付型データにはカスタム コンバーターが必要です。
カスタム型コンバーターの開発手順:
① Converter インターフェイスを実装するコンバーター クラスを定義します。
public class DateConverter implements Converter<String, Date> { @Override public Date convert(String source) { SimpleDateFormat format=new SimpleDateFormat("yyyy-MM-dd"); Date date = null; try { date = format.parse(source); } catch (ParseException e) { e.printStackTrace(); } return date; } }
② spring-mvc.xml で構成します。ファイル内でコンバータ
<!--配置自定义转换器--> <bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean"> <property name="converters"> <list> <bean class="converter.DateConverter"/> </list> </property> </bean>
を宣言する ③
<!--注解驱动--> <mvc:annotation-driven conversion-service="conversionService"/>
を参照する 6. リクエスト ヘッダー
@RequestHeader
## を取得する# @RequestHeader を使用して、Web ステージで学習した request.getHeader(name) に相当するリクエスト ヘッダー情報を取得します。@RequestHeader によってアノテーションが付けられる属性は次のとおりです:value
required | このリクエスト ヘッダーを含める必要があるかどうか | |||
value | 指定cookie的名称 |
required | 是否必须携带此cookie |
@RequestMapping("/quick18") @ResponseBody public void quickMethod18(@CookieValue(value = "JSESSIONID",required = false) String jsessionid){ System.out.println(jsessionid); }
7.文件上传
文件上传客户端三要素:
表单项type=“file”
表单的提交方式是post
表单的enctype属性是多部分表单形式,及enctype=“multipart/form-data”
<form action="${pageContext.request.contextPath}/quick20" method="post" enctype="multipart/form-data"> 名称:<input type="text" name="name"><br> 文件:<input type="file" name="file"><br> <input type="submit" value="提交"><br> </form>
文件上传步骤
① 在pom.xml导入fileupload和io坐标
<!--文件下载--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</version> </dependency>
② 配置文件上传解析器
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="defaultEncoding" value="UTF-8"/> <property name="maxUploadSize" value="500000"/> </bean>
③ 编写文件上传代码
@RequestMapping("/quick8") @ResponseBody public void save8(String name, MultipartFile uploadfile) { System.out.println("save8 running..."); System.out.println(name); String filename = uploadfile.getOriginalFilename(); try { uploadfile.transferTo(new File("D:\\upload\\"+filename)); } catch (IOException e) { e.printStackTrace(); } }
以上がSpringMVCでリクエストデータを取得するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

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

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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