Spring MVC Controller 문자 인코딩 문제

3416 단어 springmvccontroller
springMVC 프레임워크를 사용하여 웹 응용 프로그램을 구축하면 클라이언트는 문자열, 정형, json 등 형식의 데이터를 요청합니다. 보통 @ResponseBody 주석을 사용하여 컨트롤러가 페이지를 렌더링하지 않고 해당하는 데이터에 응답하도록 합니다.만약 요청한 문자열이 영문 형식이 아닌 문자열이라면, 종종 클라이언트에 표시된 것은 난호이다.스프링의 String Http Message Converter의 기본 문자 형식은 iso8895-1'서구어'이기 때문에 중국어 등 문자는 따로 지정해야 합니다.
여기에는 다음과 같은 몇 가지 솔루션이 요약되어 있습니다.
1. @ResponseBody 메모를 사용하지 않고 HttpServeletResponse를 사용하여 contentType 속성을 설정합니다.

@RequestMapping(value ="/rest/create/document") 
public void create(Document document, HttpServletRespone respone) { 
repoonse.setContentType("text/plain;charset='utf-8'"); 
response.write(" string"); 
}
2. Response Entity object로 돌아가 contentType을 설정합니다. 예:

@RequestMapping(value = "/rest/create/document") public ResponseEntity<String> create(Document document, HttpServletRespone respone) { 
HttpHeaders responseHeaders = new HttpHeaders(); responseHeaders.add("Content-Type", "text/html; charset=utf-8"); 
Document newDocument = DocumentService.create(Document); 
String json = jsonSerializer.serialize(newDocument); 
return new ResponseEntity<String>(json, responseHeaders, HttpStatus.OK); 
}
3. produces 속성 사용:

@RequestMapping(value = "/rest/create/document",produces= "text/plain;charset=UTF-8") // 
@ResponseBody 
public String create(Document document, HttpServletRespone respone) throws UnsupportedEncodingException { 
Document newDocument = DocumentService.create(Document); 
return jsonSerializer.serialize(newDocument); 
}
@RequestMapping
매개변수 바인딩(@RequestParam, @RequestBody, @RequestHeader, @PathVariable)

package org.springframework.web.bind.annotation;

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import org.springframework.web.bind.annotation.Mapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Mapping
public @interface RequestMapping {
  String name() default "";

  String[] value() default {};

  RequestMethod[] method() default {};

  String[] params() default {};

  String[] headers() default {};

  String[] consumes() default {};

  String[] produces() default {};
}

RequestMapping은 요청 주소의 매핑을 처리하는 데 사용되는 주석으로 클래스나 방법에 사용할 수 있습니다.클래스에 사용됩니다. 클래스의 모든 응답 요청을 표시하는 방법은 이 주소를 부모 경로로 합니다.
RequestMapping 메모에는 6개의 속성이 있습니다.
1、value, method;
value: 요청한 실제 주소를 지정합니다. 지정한 주소는 URI Template 모드일 수 있습니다. (뒤에 설명할 것입니다.)
method: 요청한 method 유형, GET, POST, PUT, DELETE 등을 지정합니다.
2、consumes,produces;
consumes: 처리 요청의 제출 내용 유형(Content-Type)을 지정합니다. 예를 들어 응용 프로그램/json,text/html;
produces: 되돌아오는 내용 형식을 지정합니다. 리퀘스트 요청 헤더의 (Accept) 형식에 이 지정한 형식이 포함되어야만 되돌아옵니다.
3、params,headers;
params: 리퀘스트에 어떤 매개 변수 값을 포함해야 이 방법을 처리할 수 있도록 지정합니다.
headers: 지정request에 특정한 header 값을 포함해야 요청을 처리할 수 있습니다.
이상은 본문의 전체 내용입니다. 여러분의 학습에 도움이 되고 저희를 많이 응원해 주십시오.

좋은 웹페이지 즐겨찾기