ホームページ >Java >&#&チュートリアル >SpringMVCでリクエストデータを取得するにはどうすればよいですか?

SpringMVCでリクエストデータを取得するにはどうすればよいですか?

王林
王林転載
2023-05-09 22:04:071572ブラウズ

    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 : &#39;application/json;charset=utf-8&#39;
    });
    </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/"/>

    • または、19133d400eedd6f726b93e2e2039f894 タグ

    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 には、使用できる次のパラメータもあります:

    #
    @RequestMapping("/quick14")
    @ResponseBody
    public void quickMethod14(@RequestParam(value="name",required = 
    false,defaultValue = "defaultname") String username) throws IOException {
    System.out.println(username);
    }
    value : リクエスト パラメータ名
    必須: 指定されたリクエスト パラメータを含める必要があるかどうか。そのようなパラメータがない場合、デフォルトは true です。送信時にエラーが報告されます
    defaultValue: リクエストパラメータが指定されていない場合、指定されたデフォルト値が割り当てに使用されます
    4. Restful スタイル パラメータを取得する

    Restful はソフトウェア アーキテクチャ スタイルおよび設計スタイルであり、標準ではなく、一連の設計原則と制約を提供するだけです。これは主にクライアント/サーバー対話型ソフトウェアに使用され、このスタイルに基づいて設計されたソフトウェアは、よりシンプルで、より階層化されており、キャッシュ メカニズムの実装が容易になります。

    Restful スタイルのリクエストでは、「URL リクエスト メソッド」を使用してリクエストの目的を示します。操作方法を示す HTTP プロトコルの 4 つの動詞は次のとおりです:

    GET: リソースを取得##DELETE:PUT:リソースの更新POST:新しいリソース #例:
    リソースを削除

    /user/1 GET: ID = 1 id = 1 の useruserAdd new user 上記 URL の address/user/1 は取得するリクエストパラメータで、プレースホルダは取得できます。 SpringMVCで使用されるパラメータバインディングを実行します。アドレス /user/1 は /user/{id} として記述でき、プレースホルダー {id} は値 1 に対応します。ビジネス メソッドでは、@PathVariable アノテーションを使用してプレースホルダーの一致を取得できます。
    //http://localhost:8080/itheima_springmvc1/quick19/zhangsan
    @RequestMapping("/quick19/{name}")
    @ResponseBody
    public void quickMethod19(@PathVariable(value = "name",required = true) String name){
    System.out.println(name);
    }
    5. カスタム型コンバーター
    /user/1 のユーザーを取得 DELETE:
    /user/1 を削除 PUT:
    user を更新id = 1 POST :

    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このリクエスト ヘッダーを含める必要があるかどうか
    @RequestMapping("/quick17")
    @ResponseBody
    public void quickMethod17(@RequestHeader(value = "User-Agent",required = false) String 
    headerValue){
        System.out.println(headerValue);
    }

    @CookieValue                         

    使用@CookieValue可以获得指定Cookie的值                       @CookieValue注解的属性如下:

    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 サイトの他の関連記事を参照してください。

    声明:
    この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。