Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 오라클
- ibatis parameter
- IT·컴퓨터
- Spring
- 외래키
- 예제
- ibatis 개행
- SEQUENCE
- MVC
- ibatis bind
- 개행처리
- Eclipse
- 연동
- IO
- java
- 이클립스
- 우편번호
- Android SDK
- Android
- iPhone
- Objective C
- Oracle
- zipcode
- SQL
- 아이폰
- 안드로이드
- 스프링
- 자바
- 설치
- jdbc
Archives
- Today
- Total
MisoBoy Blog...
Spring View를 Json 구현하기 (Json을 이용한 Ajax 컨트롤) 본문
1. MessageConverters 를 사용해서 json view 구현
web.xml
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>*.st</url-pattern>
</servlet-mapping>
확장자를 .st로 했습니다.
dispatcher-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<context:component-scan base-package="com.ajax" />
<bean id="handlerMapping" class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" p:alwaysUseFullPath="true" />
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" p:alwaysUseFullPath="true">
<property name="messageConverters">
<list>
<bean class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"></bean>
</list>
</property>
</bean>
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/checkloginid/"></property>
<property name="suffix" value=".jsp" />
</bean>
</beans>
컨트롤로 클래스 자동스캔을 사용했습니다. <context:component-scan base-package="com.ajax" />
handermapping를 DefaultAnnotationHandlerMapping과 AnnotationMethodHandlerAdapter 를 사용했습니다. 여기에서 messageConverter를 등록할 때는 AnnotationMethodHandlerAdapter 해줘야하기때문에
AnnotationMethodHandlerAdapter 에 MappingJacksonHttpMessageConverter messageConverters를 설정했습니다. json으로
Controller 클래스
@Controller
public class LoginController {
@RequestMapping(value="/checkloginids/{loginId}" , method=RequestMethod.GET)
@ResponseBody
public Map checklogins(@PathVariable String loginId){
Map<String, String> map=new HashMap<String, String>();
map.put("firstname", "이");
map.put("secondname", "정x");
return map;
}
@RequestMapping("/listtypeModelAndView")
@ResponseBody
public Model listtypeModelAndView(Model model){
System.out.println("listtypeModelAndView");
String[] s=null;
s=new String[4];
s[0]="1";
s[1]="2";
s[2]="3";
s[3]="4";
String[] s1=new String[4];
s1[0]="11";
s1[1]="21";
s1[2]="31";
s1[3]="41";
List<String[]> listuserInfo=new ArrayList<String[]>();
listuserInfo.add(s);
listuserInfo.add(s1);
List<Map> listjob=new ArrayList<Map>();
Map<String, String> map=new HashMap<String, String>();
map.put("firstname", "이");
map.put("secondname", "정x");
listjob.add(map);
model.addAttribute("userInfo", listuserInfo);
model.addAttribute("jobInfo", listjob);
//결과 {"userInfo":[["1","2","3","4"],["11","21","31","41"]],"jobInfo":[{"secondname":"\uc815\ud658","firstname":"\uc774"}]}
return model;
}
}
@ResponseBody 를 해주는데 @ResponseBody는
이 애노테이션이 붙은 파라미터에는 HTTP 요청이 본문 body부분이 그대로 전달된다. 일반적인 GET/POST의 요청 파라미터라면 @ResponseBody를 사용할 일이 없을 것이다. 반면 xml이나 json 기반의 메시지를 사용하는 요청의 경우에는 이방법이 매우 유용하다.
AnnotationMethodHandlerAdapter에는 HttpMessageConverter 타입의 메시지 변환기가 여러개 등록되어 있다. @ResponseBody가 붙은 파라미터가 있으면 HTTP요청의 미디어 타입과 파라미터의 타입을 먼저 확인한다. 메시지 변환기 중에서 해당 미디어 타입과 파라미터 타입을 처리할 수 있는 것이 있다면, HTTP 요청의 본문부분을 통째로 변환해서 지정된 메소드 파라미터로 전달해준다. -토비의 스프링 3 page-1153
리턴해주는 type이나 방법을 몇가지로 해봤는데 model로 하는게 가장 유용할 것 같다.
jsp 파일
<script src="http://code.jquery.com/jquery-1.4.4.js"></script>
<script src="js/json2.js"></script>
<script type="text/javascript">
$(document).ready(function() {
printResult = function(data){
var result =
"Json-Result:"
+ "\n" + JSON.stringify(data);
alert(data);
document.write(result);
};
//$.getJSON('checkloginids/hosincool.st',
//$.getJSON('listtype.st',
//$.getJSON('listtypeModelAndView.st',
$.getJSON('string.st',
function(data){
printResult(data);
$('#firstname').html(data.firstname);
$('#secondname').html(data.secondname);
});
});
</script>
2. MappingJacksonJsonView 를 사용한 json view 구현
dispacher-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context" xmlns:p="http://www.springframework.org/schema/p"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<bean id="jsonController" class="com.ajax.JsonController" />
<bean id="viewResolver" class="org.springframework.web.servlet.view.BeanNameViewResolver" />
<bean id="jsonReport" class="org.springframework.web.servlet.view.json.MappingJacksonJsonView"/>
</beans>
Controller 클래스
@Controller
public class JsonController {
@RequestMapping("/jsonReport")
public ModelAndView jsonReport(){
List<Map<String, String>> pageRanks=new ArrayList<Map<String,String>>();
Map map=new HashMap<String, String>();
map.put("1", "하나");
Map map1=new HashMap<String, String>();
map1.put("2", "둘");
Map map2=new HashMap<String, String>();
map2.put("3", "셋");
map2.put("3", "넷");
map2.put("3", "뭐지");
map2.put("name", map1);
pageRanks.add(map1);
pageRanks.add(map2);
return new ModelAndView("jsonReport","report",pageRanks);
}
@RequestMapping("/jsonReport2")
public ModelAndView jsonReport2(){
Map map1=new HashMap<String, String>();
map1.put("job_name", "what!");
map1.put("office_name", "xxxxㅌ");
Map map2=new HashMap<String, String>();
map2.put("name", "바람소리");
map2.put("tel", "010-000000");
map2.put("id", "vishvoice");
map2.put("age","30");
/**
* 아래처럼 addObject("","");이렇 해주면 json {userInfo:{'',''},jobinfo:{'',''}}
* 이렇게 나온다.
* 허나 ModelAndView로 하지 않고.. Map 타입으로하면 userInfo와 jobinfo 두개를 줄수있는 방법을
* 못 찾았다.
*/
ModelAndView modelAndView=new ModelAndView("jsonReport");
modelAndView.addObject("userInfo", map2);
modelAndView.addObject("jobinfo", map1);
return modelAndView;
}
}
view를 MappingJacksonJsonView로 했기 때문에 view id를 ModelAndView modelAndView=new ModelAndView("jsonReport");이렇게 해주면 된다.
jsp
<script src="http://code.jquery.com/jquery-1.4.4.js"></script>
<script src="js/json2.js"></script>
<script type="text/javascript">
$(document).ready(function() {
printResult = function(data){
var result =
"Json-Result:"
+ "\n" + JSON.stringify(data);
alert(result);
};
$.getJSON('down/jsonReport2',
function(data){
printResult(data);
$('#firstname').html(data.firstname);
$('#secondname').html(data.secondname);
});
});
</script>
'Spring framework' 카테고리의 다른 글
[토비스프링] 12장 스프링 웹기술과 스프링 MVC (0) | 2012.09.18 |
---|