SpringMvc(6)-10.14上传、拦截器

1.SpringMVC实现文件上传:
和Servlet方式的本质一样,都是通过commons-fileupload.jar和commons-io.jar
SpringMVC可以简化文件上传的代码,但是必须满足条件:实现MultipartResolver接口;而该接口的实现类SpringMVC也已经提供了CommonsMultipartResolver

具体步骤:(直接使用CommonsMultipartResolver实现上传)
a.jar包
commons-fileupload.jar、commons-io.jar
b.配置CommonsMultipartResolver
将其加入SpringIOC容器

		
	<!-- 配置CommonsMultipartResolver,用于实现文件上传
	将其加入SpringIOC容器.
	springIoc容器在初始化时,会自动寻找一个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="104857600"></property>
	</bean>

c.处理方法

		//文件上传处理方法
		@RequestMapping(value="testUpload") //abc.png
		public String testUpload(@RequestParam("desc") String desc  , @RequestParam("file") MultipartFile file  ) throws IOException {
			
			System.out.println("文件描述信息:"+desc);
			//jsp中上传的文件:file
			
			InputStream input = file.getInputStream() ;//IO
			String fileName = file.getOriginalFilename() ;
			
			OutputStream out = new FileOutputStream("d:\\"+fileName) ;
			
			
			byte[] bs = new byte[1024];
			int len = -1;
			while(( len = input.read(bs)) !=-1 ) {
				out.write(bs, 0, len);
			}
			out.close();
			input.close();
			//将file上传到服务器中的 某一个硬盘文件中
		System.out.println("上传成功!");
			
			return "success";
		}

	<form action="handler/testUpload" method="post"  enctype="multipart/form-data">
		<input type="file" name="file" />
		描述:<input name="desc" type="text" />
		
		<input type="submit" value="上传">
	</form>
	<form action="handler/testUpload" method="post"  enctype="multipart/form-data">
		<input type="file" name="file" />
		描述:<input name="desc" type="text" />
		
		<input type="submit" value="上传">
	</form>

框架:将原来自己写的1000行代码,变成:框架帮你写900行,剩下100行自己写

控制器:handler/servlet/controller/action

2.拦截器
拦截器的原理和过滤器相同。
SpringMVC:要想实现拦截器,必须实现一个接口HandlerInterceptor

ctrl+shift+r :自己编写的代码.java .jsp .html
ctrl+shift+t :jar中的代码

a.编写拦截器implements HandlerInterceptor

package org.lanqiao.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 boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
			throws Exception {
		System.out.println("拦截请求");  //
		return true;//true:拦截操作之后,放行 ;false:拦截之后不放行,请求终止;
	}

	@Override
	public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler,
			ModelAndView modelAndView) throws Exception {
		System.out.println("拦截响应");
	}

	@Override
	public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex)
			throws Exception {
		System.out.println("视图(jsp)被渲染完毕");
	}

}

b.配置:将自己写的拦截器配置到springmvc中(spring)

<!-- 将自己写的拦截器 配置到springmvc中(spring);默认拦截全部请求 -->
	<mvc:interceptors>
		
			<!-- 配置具体的拦截路径 -->
			<mvc:interceptor>
				<!-- 指定拦截的路径,基于ant风格 -->
				<mvc:mapping path="/**"/>  
				<!-- 指定拦不截的路径 -->
				<mvc:exclude-mapping path="/handler/testUpload"/> 
				<bean  class="org.lanqiao.interceptor.MyInterceptor"></bean>
			</mvc:interceptor>
			
				<!-- 配置具体的拦截路径 -->
			<mvc:interceptor>
				<!-- 指定拦截的路径,基于ant风格 -->
				<mvc:mapping path="/**"/>  
				<!-- 指定拦不截的路径 -->
				<mvc:exclude-mapping path="/handler/testUpload"/> 
				<bean  class="org.lanqiao.interceptor.MySecondInterceptor"></bean>
			</mvc:interceptor>
	</mvc:interceptors>

拦截器1拦截请求- 拦截器2拦截请求 - 请求方法 - 拦截器2处理相应-拦截器1处理相应- 只会被最后一个拦截器的afterCompletion()拦截

如果有多个拦截器,则每个拦截器的preHandle postHandle都会在相应时机各被触发一次;但是afterCompletion,只会执行最后一个拦截器的该方法。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值