zoukankan      html  css  js  c++  java
  • Springmvc中ajax与jason应用

    Springmvc中ajax与jason应用

    相关依赖包

    json数据转换的jar包

    jackson-annotations-2.5.4
    jackson-core-2.5.4
    jackson-databind-2.5.4

    spring以及spring的依赖包

    bean context aop context core web webmvc expression

    未涉及json的ajax请求

    简单的表单验证

    Controller层java代码

    @Controller
    public class AjaxCtrl {
    	@RequestMapping("/toAjax.do")
    	public String toAjax() {
    		return "ajax";
    	}
    	@RequestMapping("/ajax.do")
    	@ResponseBody
    	public void ajaxJson(@RequestParam("name")String name,HttpServletResponse resp) throws IOException {
    		PrintWriter out = resp.getWriter();
    		if(name.equals("hm"))
    			out.print("该用户已注册");
    		else
    			out.print("该用户可使用");
    	}
    

    注意点:

    • 在手动调用getWriter()方法时不可以再添加返回值,否则tomcat会报错(getWriter()方法已存在)。因为在返回值处容器会自动调用getWriter()方法来输出内容,而检测到前面getWriter()已经被调用过,产生冲突。
    • 解决:1. 像上面的代码不给出返回值;2. resp.reset(); resp.setContentType("text/html; charset=utf-8"); out.flush; out.close();
    • @ResponseBody会将返回的数据自动转换为json格式的数据

    相关jsp代码:ajax.jsp

    <script src="${pageContext.request.contextPath }/js/jquery-2.1.0.min.js" type="text/javascript"></script>
    </head>
    <body>
    	姓名:<input type="text" id="field" name="name" /><span id="txt"></span>
    	<script type="text/javascript">
    		$("#field").blur(function(){
    			$.post("ajax.do",{'name':$('#field').val()},function(result){
    				$("#txt").html(result);
    			});
    		});
    	</script>
    </body>
    

    web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xmlns="http://xmlns.jcp.org/xml/ns/javaee"
    	xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
    	id="WebApp_ID" version="3.1">
    	<display-name>springmvc_ajax</display-name>
    	<filter>
    		<filter-name>characterencoding</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>
    		<init-param>
    			<param-name>forceEncoding</param-name>
    			<param-value>true</param-value>
    		</init-param>
    	</filter>
    	<filter-mapping>
    		<filter-name>characterencoding</filter-name>
    		<url-pattern>*.do</url-pattern>
    	</filter-mapping>
    	<servlet>
    		<servlet-name>ajax</servlet-name>
    		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    		<init-param>
    			<param-name>contextConfigLocation</param-name>
    			<param-value>classpath:mvc.xml</param-value>
    		</init-param>
    		<load-on-startup>1</load-on-startup>
    	</servlet>
    	<servlet-mapping>
    		<servlet-name>ajax</servlet-name>
    		<url-pattern>*.do</url-pattern>
    	</servlet-mapping>
    </web-app>
    

    涉及json格式数据的ajax请求

    Controller层java代码

    @RequestMapping("/toAjaxJson.do")
    	public String toAjaxJson() {
    		return "ajaxJson";
    	}
    	@RequestMapping("/ajaxJson.do")
    	@ResponseBody
    	public List<User> ajaxJson() {
    		List<User> list = new ArrayList<User>();
    		list.add(new User(1, "xb", "123"));
    		list.add(new User(2, "xc", "234"));
    		list.add(new User(3, "xd", "345"));
    		list.add(new User(4, "xa", "456"));
    		return list;
    	}
    

    相关jsp代码:ajaxJson.jsp

    <input type="button" id="btn" value="获取json数据">
    	<table  width="80%" align="center">
    		<tr>
    			<th>编号</th>
    			<th>姓名</th>
    			<th>密码</th>
    		</tr>
    		<tbody id="content"></tbody>
    	</table>
    	<script type="text/javascript">
    	$(function(){
    		$("#btn").click(function(){
    			$.get("ajaxJson.do",function(list){
    				var field = "";
    				for (var i = 0; i < list.length; i++) {
    					field +="<tr><td>"+list[i].id+"</td>"+"<td>"+list[i].name+"</td>"+"<td>"+list[i].passwd+"</td></tr>";
    				}
    				$("#content").html(field);
    			});
    		});
    	});
    	</script>
    

    springmvc的核心配置文件:mvc.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
    	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    	xmlns:context="http://www.springframework.org/schema/context"
    	xmlns:mvc="http://www.springframework.org/schema/mvc"
    	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
    		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.1.xsd
    		http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
    	<!-- 开启mvc的注解 -->
    	<mvc:annotation-driven />
    	<!-- 扫描包 -->
    	<context:component-scan base-package="com.zrm.controller"></context:component-scan>
    	<!-- 配置视图解析器 -->
    	<bean id="InternalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    		<property name="prefix" value="/WEB-INF/views/"></property>
    		<property name="suffix" value=".jsp"></property>
    	</bean>
    	<bean id="stringConverter" class="org.springframework.http.converter. StringHttpMessageConverter">
    		<property name="supportedMediaTypes">
    			<list>
    				<value>text/plain;charset=UTF-8</value>
    			</list>
    		</property>
    	</bean>
    	<bean id="jsonConverter" class="org.springframework.http.converter.json. "></bean>
    	<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
    		<property name="messageConverters">
    			<list>
    				<ref bean="stringConverter"/>
    				<ref bean="jsonConverter"/>
    			</list>
    		</property>
    	</bean>	
    </beans>
    

    相关类的介绍

    StringHttpMessageConverter

    官方文档:
    An HttpMessageConverter implementation that can read and write Strings from the HTTP request and response. By default, this converter supports all text media types (text/*), and writes with a Content-Type of text/plain.

    译文:
    一种HttpMessageConverter可以从HTTP请求和响应中读取和写入字符串的实现。默认情况下,此转换器支持所有文字媒体类型(text/*),并用Content-Type中的text/plain类型。

    MappingJackson2HttpMessageConverter

    官方文档:
    An HttpMessageConverter implementation that can read and write JSON using Jackson’s ObjectMapper. JSON mapping can be customized as needed through the use of Jackson’s provided annotations. When further control is needed, a custom ObjectMapper can be injected through the ObjectMapper property for cases where custom JSON serializers/deserializers need to be provided for specific types. By default this converter supports ( application/json).

    译文:
    一个HttpMessageConverter可以使用Jackson库提供的ObjectMapper类来读取和写入json格式的数据。可以根据需要通过使用Jackson库提供的注解来自定义XML映射。当需要进一步控制时,XmlMapper 可以通过ObjectMapper属性注入自定义,以用于需要为特定类型提供自定义XML序列化器/反序列化器的情况。默认情况下,此转换器支持(application/xml)。

    ObjectMapper是Jackson库的主要类,他提供的一些功能用于将Java对象转换为符合jason结构的字符串。

    AnnotationMethodHandlerAdapter

    注入了AnnotationMethodHandlerAdapter作用是对有RequestMapping注解的控制器进行HTTP路径、HTTP方法和请求参数解析.

    项目结构

    ajaxJson

    项目源码已上传至 github ajaxJson

  • 相关阅读:
    Web Workers 的基本信息
    关于前端框架的一些观点
    解密jQuery内核 DOM操作方法(二)html,text,val
    解密jQuery内核 DOM操作
    解密jQuery内核 DOM操作的核心buildFragment
    解密jQuery内核 DOM操作的核心函数domManip
    前端MVC框架Backbone 1.1.0源码分析(二)
    前端MVC框架Backbone 1.1.0源码分析(一)
    解密jQuery内核 Sizzle引擎筛选器
    解密jQuery事件核心
  • 原文地址:https://www.cnblogs.com/randolf/p/10718588.html
Copyright © 2011-2022 走看看