> 웹 프론트엔드 > JS 튜토리얼 > Spring의 여러 Ajax 및 백그라운드 데이터 전송 방법 소개

Spring의 여러 Ajax 및 백그라운드 데이터 전송 방법 소개

coldplay.xixi
풀어 주다: 2020-12-04 16:27:51
앞으로
7829명이 탐색했습니다.

ajax백그라운드로 데이터를 전송하는 방법을 소개하는 칼럼입니다

Spring의 여러 Ajax 및 백그라운드 데이터 전송 방법 소개

추천(무료) : ajax

최근 Ajax를 작성하고 백그라운드로 데이터를 전송할 때 문제가 발생했습니다. json 형태로 데이터를 백그라운드로 전송하고 백그라운드에서 맵 형태로 수신한 후 맵 형태로 데이터를 반환합니다. 그런데 프런트에서 계속 오류 메시지(*)(@415 지원되지 않는 미디어 유형)가 떴고, 안내사항을 참고한 끝에 해결했습니다. 다음은 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>
로그인 후 복사
백엔드:

<code></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. 데이터에 넣기
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>
로그인 후 복사
백엔드(두 가지 방법):

<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>
로그인 후 복사
백엔드:
<code><p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">@RequestMapping(value = "getPeopleById", produces = "application/json")
@ResponseBody
public Map<String, Object> getPeopleById(@RequestBody Map<String, Object> body){
    System.out.println(""+body.get("id"));
    People people = peopleService.getPeopleById(Integer.valueOf((String)body.get("id")));
    Map<String, Object> map = new HashMap<String, Object>();
    map.put("result", people);
    return map;
}
로그인 후 복사

자세한 설명:
@RequestBody

이 주석은 먼저 요청 요청의 본문 데이터를 읽은 다음 기본 구성된 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: 바이너리 형식의 데이터를 읽고 바이너리 형식으로 데이터를 쓰는 일을 담당합니다. 문자열 형식의 데이터 읽기 및 바이너리 형식의 데이터 쓰기
ResourceHttpMessageConverter: 리소스 파일 읽기 및 리소스 파일 데이터 쓰기를 담당
FormHttpMessageConverter: 양식에서 제출된 데이터 읽기를 담당
MappingJacksonHttpMessageConverter: json 형식의 데이터 읽기 및 쓰기
SouceHttpMessageConverter: xml의 javax.xml.transform.Source에 의해 정의된 데이터 읽기 및 쓰기를 담당합니다.
Jaxb2RootElementHttpMessageConverter: xml 태그 형식 데이터 읽기 및 쓰기를 담당합니다. : Atom 형식의 데이터를 읽고 쓰는 역할
RssChannelHttpMessageConverter: RSS 형식의 데이터를 읽고 쓰는 역할
프로젝트에서는 json 변환기만 사용하므로 import해야 함 json 패키지에 대해; ):

<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 training
칼럼을 주목해주세요!

위 내용은 Spring의 여러 Ajax 및 백그라운드 데이터 전송 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:jianshu.com
이전 기사:JavaScript Web Worker의 구성 요소와 5가지 사용 시나리오 다음 기사:JavaScript에서 모듈, 가져오기 및 내보내기에 대해 자세히 알아보기
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
관련 주제
더>
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿