Spring での ajax およびバックグラウンド データ送信のいくつかの方法の紹介

coldplay.xixi
リリース: 2020-12-04 16:27:51
転載
7803 人が閲覧しました

ajaxバックグラウンドでデータを送信する方法を紹介するコラム

Spring での ajax およびバックグラウンド データ送信のいくつかの方法の紹介

おすすめ(無料): ajax

最近、ajax を作成してバックグラウンドにデータを送信するときに問題が発生しました。ajax がデータを json 形式でバックグラウンドに送信するようにしたいのですが、バックグラウンドはそれを次の形式で受信します。マップのデータを取得し、マップの形式でデータを返します。しかし、フロントデスクでエラーメッセージ(*) (@415 Unsupported media type) が何度も表示され、情報を参照してようやく解決しました。ここでは、ajax とバックグラウンドの間でデータを送信するいくつかの方法をまとめています。上記の問題の解決策はこの記事の最後にあります。


1. URL にデータを入れて渡します
js:
<code>
var id = $("#id").val();
$.ajax({
type: "POST",
url: "/IFTree/people/getPeopleById/"+id,//参数放在url中
success:function(data){ alert(data);
},
error:function(xhr, textStatus, errorThrown) {
}
});
</code>
ログイン後にコピー
Backend:

<code&gt ;</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">@RequestMapping(value = "getPeopleById/{id}")
@ResponseBody
    public Map<String, Object> getPeopleById(@PathVariable("id") int id) {
        //@PathVariable("id") 如果参数名与url定义的一样注解可以不用定义("id")
        System.out.println(id);
        Map<String, Object> map = new HashMap<String, Object>();
        return map;
    }
}
ログイン後にコピー

2. データを data
js に配置します:
<code>
var id = $("#id").val();
$.ajax({
type: "POST",
url: "/IFTree/people/getPeopleById",
data: {id:id},
success:function(data){ alert(data.result);
},
error:function(xhr, textStatus, errorThrown) {
}
});
</code>
ログイン後にコピー
Backend (2 つのメソッド) ):

<code></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">@RequestMapping(value = "getPeopleById")
@ResponseBody
public Map<String, Object> getPeopleById(HttpServletRequest request,HttpServletResponse response) {
    int id = Integer.valueOf(request.getParameter("id"));
    Map<String, Object> map = new HashMap<String, Object>();
    return map;
}
ログイン後にコピー


@RequestMapping(value = "getPeopleById")
@ResponseBody
public Map<String, Object> getPeopleById(HttpServletRequest request,HttpServletResponse response) {
    int id = Integer.valueOf(request.getParameter("id"));
    // 这里得到的都是字符串得转换成你需要的类型
    Map<String, Object> map = new HashMap<String, Object>();
    return map;
}
ログイン後にコピー

3. json で送信 (冒頭で述べた状況)
js (いくつかの一般的な ajax パラメーターの説明を含む):
<code>
var id = $("#id").val();
$.ajax({
type: "POST",//请求类型
timeout:10000,  //设置请求超时时间(毫秒)
async:ture,//是否为异步请求
cache:false,//是否从浏览器缓存中加载请求信息。
url: "/IFTree/people/getPeopleById",
contentType: "application/json;charset=UTF-8",//提交的数据类型
data: JSON.stringify({id:id}),//这里是把json转化为字符串形式
dataType: "json",//返回的数据类型
success:function(data){
$("#name").val(data.result.name);
},
error:function(xhr, textStatus, errorThrown) {
}
});
});
</code>
ログイン後にコピー
Backend:

< pre></p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">@RequestMapping(value = &quot;getPeopleById&quot;, produces = &quot;application/json&quot;) @ResponseBody public Map&lt;String, Object&gt; getPeopleById(@RequestBody Map&lt;String, Object&gt; body){ System.out.println(&quot;&quot;+body.get(&quot;id&quot;)); People people = peopleService.getPeopleById(Integer.valueOf((String)body.get(&quot;id&quot;))); Map&lt;String, Object&gt; map = new HashMap&lt;String, Object&gt;(); map.put(&quot;result&quot;, people); return map; }</pre><div class="contentsignin">ログイン後にコピー</div></div><p>

詳細な説明:

@RequestBody
このアノテーションは、最初にリクエスト request を読み取ります。テキスト データを解析し、デフォルトで構成された HttpMessageConverter を使用してデータをオブジェクトにバインドし、オブジェクトをコントローラーのパラメーターにバインドします。
@ResponseBody
このアノテーションは、Controller メソッドから返されたオブジェクトを HttpMessageConverter を通じて指定された形式に変換し、Response オブジェクトの本文データ領域に書き込むためにも使用されます。

Srping mvc .xml (構成コンバーター)

</p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"> &lt;!-- spring MVC提供的适配器 spring默认加载 (如果不修改默认加载的4类转换器,该bean可不配置)--&gt; &lt;bean class=&quot;org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter&quot;&gt; &lt;property name=&quot;messageConverters&quot;&gt; &lt;!-- 该适配器默认加载以下4类转换器--&gt; &lt;list&gt; &lt;bean class=&quot;org.springframework.http.converter.BufferedImageHttpMessageConverter&quot; /&gt; &lt;bean class=&quot;org.springframework.http.converter.ByteArrayHttpMessageConverter&quot; /&gt; &lt;bean class=&quot;org.springframework.http.converter.xml.SourceHttpMessageConverter&quot; /&gt; &lt;bean class=&quot;org.springframework.http.converter.xml.XmlAwareFormHttpMessageConverter&quot; /&gt; &lt;bean class=&quot;org.springframework.http.converter.StringHttpMessageConverter&quot; /&gt; &lt;bean class=&quot;org.springframework.http.converter.json.MappingJacksonHttpMessageConverter&quot;&gt; &lt;property name=&quot;supportedMediaTypes&quot;&gt; &lt;list&gt; &lt;value&gt;application/json;charset=UTF-8&lt;/value&gt; &lt;/list&gt; &lt;/property&gt; &lt;/bean&gt;&lt;!--这里配置了json转换器支持的媒体类型--&gt; &lt;/list&gt; &lt;/property&gt; &lt;/bean&gt;</pre><div class="contentsignin">ログイン後にコピー</div></div><p>
ByteArrayHttpMessageConverter: 読み取りを担当しますバイナリ形式でのデータの取得とバイナリ形式でのデータの書き込み;
StringHttpMessageConverter: 文字列形式でのデータの読み取りとバイナリ形式でのデータの書き込みを担当します;
ResourceHttpMessageConverter : 以下を担当しますリソース ファイルの読み取りとリソース ファイル データの書き込み;
FormHttpMessageConverter: フォームによって送信されたデータの読み取りを担当します
MappingJacksonHttpMessageConverter: json 形式のデータの読み取りと書き込みを担当します;
SouceHttpMessageConverter: xml の javax.xml.transform.Source で定義されたデータの読み取りおよび書き込みを担当します。
Jaxb2RootElementHttpMessageConverter: XML タグ形式のデータの読み取りおよび書き込みを担当します。
AtomFeedHttpMessageConverter: Atom 形式のデータの読み取りおよび書き込みを担当します。
RssChannelHttpMessageConverter: RSS 形式のデータの読み取りおよび書き込みを担当します。

私は、 json コンバーターがプロジェクトに含まれているため、json パッケージ (maven) をインポートする必要があります:

<code>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
<version>1.9.11</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.11</version>
</dependency>
</code>
ログイン後にコピー

同様に、コントローラー内のパラメーターもエンティティ クラスの形式で受け取ることができます。データ、
構成ファイルが正しく書き込まれず、対応するパッケージがインポートされなかったため、エラー (415 サポートされていないメディア タイプ) の報告が開始されました。
不備や間違いがある場合は、ご指摘ください。ありがとうございます。

# プログラミングについて詳しく知りたい場合は、## に注意してください。 #phpトレーニング列!

以上がSpring での ajax およびバックグラウンド データ送信のいくつかの方法の紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:jianshu.com
前の記事:JavaScript Web Workers の構成要素と 5 つの使用シナリオ 次の記事:モジュール、JavaScript でのインポートとエクスポートの詳細については、こちらをご覧ください。
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
最新の問題
関連トピック
詳細>
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート