クライアント リクエスト パラメータの形式は次のとおりです: name=value&name=value... サーバーはリクエストされたパラメータを取得する必要があります。 SpringMVC は次のタイプのパラメーターを受け取ることができます:
コントローラー内のビジネス メソッドのパラメーター名は、以下と一致している必要があります。リクエストパラメータの名前。値は自動的にマッピングされ、照合されます。
//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); }
コントローラー内のビジネス メソッドの 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); }
コントローラー内のビジネス メソッド配列の名前はリクエスト パラメーターの名前と一致しており、パラメーター値は自動的にマッピングおよび照合されます。 。
//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)); }
コレクション パラメータを取得するときは、コレクション パラメータを 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/"/>
• または、
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>
アノテーション @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 アノテーションを使用してプレースホルダーの一致を取得できます。 |
ただし、すべてのデータ型にコンバーターが提供されているわけではありません。コンバーターが提供されていない場合は、コンバーターをカスタマイズする必要があります。たとえば、日付型データにはカスタム コンバーターが必要です。
カスタム型コンバーターの開発手順:
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); }
文件上传客户端三要素:
表单项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 サイトの他の関連記事を参照してください。