springMVC通过ajax处理JSON数据
需要jar包:
jackson-annotations.jar
jackson-core.jar
jackson-databin.jar
前台:服务器将返回值 以Json的格式 传给了result
<script type = "text/javascript">
$(document).ready(function(){
$("#json").click(function(){
//通过ajax方式请求springMVC
$.post(
"testjson",//服务器地址
{"name":"yq","age":23},
function(result){
alert(result[0].name);
}
)
});
});
服务端
@ResponseBody//告诉SpringMVC,此时返回的不是View页面,而是一个返回值
@RequestMapping("testjson")
public List<Person> testjson(@RequestParam("name") String name) {
//service
List<Person> person = new ArrayList<Person>();
Person per = new Person();
per.setName(name);
person.add(per);
return person;
}
文件上传
SpringMVC实现文件上传下载:
和Servlet方式的本质是一样的,都是通过commons-fileupload.jar和commons-io.jar
SpringMVC可以简化文件上传的代码,但是必须满足条件:实现MultipartResolver接口:而该接口的实现类SpringMVC也提供了CommonsMultipartResolver类
Spring MVC 为文件上传提供了直接的支持,这种支持是通过即插即用的 MultipartResolver 实现的。Spring 用Jakarta Commons FileUpload 技术实现了一个MultipartResolver 实现类:CommonsMultipartResovler
• Spring MVC 上下文中默认没有装配 MultipartResovler,因此默认情况下不能处理文件的上传工作,如果想使用 Spring 的文件上传功能,需现在上下文中配置 MultipartResolver
实现:具体步骤:(直接使用CommonsMultipartResolver实现上传)
• defaultEncoding: 必须和用户 JSP 的 pageEncoding 属性一致,以便正确解析表单的内容
• 为了让 CommonsMultipartResovler 正确工作,必须先 将 Jakarta Commons FileUpload 及 JakartaCommons io的类包添加到类路径下。
1.jar包
commons-fileupload.jar和commons-io.jar
2.配置CommonsMultipartResolver,将其加入SpringIOC容器
<!-- 配置CommonsMultipartResolver,将其加入SpringIOC容器,实现文件上传
SpringMVC容器在初始化时,会自动寻找一个ID=“multipartResolver”的bean,并将其加入IOC容器
-->
<bean id = "multipartResolver" class = "org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value = "UTF-8"></property>
<!-- 上传单个文件的最大值,单位为Byte,如果-1,表示无限制 -->
<property name="maxUploadSize" value="102400"></property>
</bean>
3.处理方法
控制器的叫法不同(handler, controller, action, servlet)
@RequestMapping("upload")
public String upload(@RequestParam("desc") String desc, @RequestParam("file") MultipartFile file) throws IOException {
System.out.println("文件描述信息 " +desc);
//jsp中上传的文件
InputStream input = file.getInputStream();
//file.getOriginalFilename()获取文件原始名字
File up = new File("D:\\learn data save\\upload",file.getOriginalFilename());
OutputStream out = new FileOutputStream(up);
//将文件上传到服务器的某一个硬盘文件中
byte[] buffer = new byte[1024];
int len = -1;
while((len=input.read(buffer))!=-1) {
out.write(buffer, 0, len);
}
System.out.println("上传成功!"+file.getOriginalFilename());
return "welcome";
}
拦截器
拦截器
拦截器实现原理与过滤器相同
SpringMVC:要想实现拦截器,必须实现一个接口HandlerInterceptor
eclipse:
ctrl+shift+r: 搜索自己写的代码:java,jsp,html
ctrl+shift+t: jar中的代码
1.编写拦截器implements HandlerInterceptor
2.配置:将自己写的拦截器 配置到SpringMVC中
多拦截器,拦截顺序
package interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class Myinterceptor implements HandlerInterceptor{
@Override
public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
System.out.println("渲染完毕");
}
@Override
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception {
System.out.println("拦截响应");
}
@Override
public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2) throws Exception {
System.out.println("拦截请求");
//返回值控制是否放行
return true;
}
}
<!-- 配置拦截器 :默认拦截全部-->
<mvc:interceptors>
<mvc:interceptor>
<!-- 指定拦截路径,基于ant风格 -->
<mvc:mapping path="/**"/>
<!-- 指定不拦截路径 -->
<mvc:exclude-mapping path="/upload"/>
<bean class="interceptor.Myinterceptor"></bean>
</mvc:interceptor>
<mvc:interceptor>
<!-- 指定拦截路径,基于ant风格 -->
<mvc:mapping path="/**"/>
<!-- 指定不拦截路径 -->
<mvc:exclude-mapping path="/upload"/>
<bean class="interceptor.Myinterceptor2"></bean>
</mvc:interceptor>
</mvc:interceptors>