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

    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/"/>

    • または、 タグ

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

    声明
    この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
    高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか?高度なJavaプロジェクト管理、自動化の構築、依存関係の解像度にMavenまたはGradleを使用するにはどうすればよいですか?Mar 17, 2025 pm 05:46 PM

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

    適切なバージョン化と依存関係管理を備えたカスタムJavaライブラリ(JARファイル)を作成および使用するにはどうすればよいですか?適切なバージョン化と依存関係管理を備えたカスタムJavaライブラリ(JARファイル)を作成および使用するにはどうすればよいですか?Mar 17, 2025 pm 05:45 PM

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

    カフェインやグアバキャッシュなどのライブラリを使用して、Javaアプリケーションにマルチレベルキャッシュを実装するにはどうすればよいですか?カフェインやグアバキャッシュなどのライブラリを使用して、Javaアプリケーションにマルチレベルキャッシュを実装するにはどうすればよいですか?Mar 17, 2025 pm 05:44 PM

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

    キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか?キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPA(Java Persistence API)を使用するにはどうすればよいですか?Mar 17, 2025 pm 05:43 PM

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

    Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか?Javaのクラスロードメカニズムは、さまざまなクラスローダーやその委任モデルを含むどのように機能しますか?Mar 17, 2025 pm 05:35 PM

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

    See all articles

    ホットAIツール

    Undresser.AI Undress

    Undresser.AI Undress

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

    AI Clothes Remover

    AI Clothes Remover

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

    Undress AI Tool

    Undress AI Tool

    脱衣画像を無料で

    Clothoff.io

    Clothoff.io

    AI衣類リムーバー

    AI Hentai Generator

    AI Hentai Generator

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

    ホットツール

    MantisBT

    MantisBT

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

    メモ帳++7.3.1

    メモ帳++7.3.1

    使いやすく無料のコードエディター

    MinGW - Minimalist GNU for Windows

    MinGW - Minimalist GNU for Windows

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

    PhpStorm Mac バージョン

    PhpStorm Mac バージョン

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

    SublimeText3 中国語版

    SublimeText3 中国語版

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