拦截器:
拦截不符合规则的,放行符合规则的。 等价于过滤器。

拦截器只拦截controller层API接口。
如何定义拦截器。
定义一个类并实现拦截器接口
public class MyInterceptor implements HandlerInterceptor {
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//获取session对象
HttpSession session=request.getSession();
//获取session当前用户的信息
Object userinfo = session.getAttribute("userinfo");
if(userinfo==null){
//没有登录,跳转到登录页面
response.sendRedirect("/login.jsp");
return false;
}
return true; //如果返回值为true,表示拦截器放行。否则,拦截器不放行
}
}
注册拦截器并配置拦截规则--springmvc配置文件中
<!--注册自定义拦截器以及拦截规则--> <mvc:interceptors> <mvc:interceptor> <!--path:拦截的路径 /**表示拦截多层路径--> <mvc:mapping path="/**"/> <!--排除的路径。--> <mvc:exclude-mapping path="/user/login"/> <!--放置自定义的拦截器类--> <bean class="com.aaa.interceptor.MyInterceptor"/> </mvc:interceptor> </mvc:interceptors>
全局异常处理
如果controller发生异常,我们需要对controller层中的所有方法都进行处理。这样比较麻烦。我们可以对所有controller中的接口提供一个统一的异常处理。
定义全局异常类
//全局异常处理类.
@ControllerAdvice
public class MyGlobalException {
@ExceptionHandler(Exception.class) //当发生Exception类型的异常会执行该方法,并异常对象传递给该方法的参数。
@ResponseBody
public String handlerException(Exception e){
System.out.println(e.getMessage());
System.out.println("错误~~~~~~~~~~~~~~~~~~~~~~~~~");
return "error2222222222222222222222";//经过视图解析器: /views/error.jsp
}
@ExceptionHandler(ArithmeticException.class)
@ResponseBody
public String handlerArithmeticException(Exception e){
System.out.println("错误****************************");
return "error2222222222222222222";
}
}
注意:保证springmvc能够扫描到该异常处理类
function loadEmp(){
$.ajax({
url:"/emp/list",
type:"get",
dataType:"json",
//服务器响应成功
success:function(data){
console.log(data)
var str="";
for(var i=0;i<data.length;i++){
str+="<tr>"
str+="<td>"+data[i].empId+"</td>"
str+="<td>"+data[i].empName+"</td>"
str+="<td>"+data[i].empJob+"</td>"
str+="<td>"+data[i].empSalary+"</td>"
str+="<td>"+data[i].dept.deptName+"</td>"
str+="<td><a οnclick='deleteEmp("+data[i].empId+")'>删除</a><a οnclick='/views/update.jsp'>修改</a></td>"
str+="</tr>"
}
document.getElementById("empBody").innerHTML=str;
},
//服务器响应故障
error: function (data){
console.log(data);
}
})
}
文件上传
原理

完成文件上传--本地服务器保存
引入文件上传的依赖jar
<!--文件上传依赖--> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.5</version> </dependency>
配置文件上传解析器
<!--文件上传解析器--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <!--最大上传的大小。单位byte字节。5M=5*1024*1024--> <property name="maxUploadSize" value="5242880"/> <!--设置文件上传的编码--> <property name="defaultEncoding" value="utf-8"/> </bean>
编写文件上传的页面
<%--文件上传的表单提交方式必须为post.而且需要设置表单提交的编码格式。enctype="multipart/form-data" 该类型表示既能上传文本又能上传文件。--%> <form action="/upload" method="post" enctype="multipart/form-data"> 选择文件:<input type="file" name="myfile"/><br> 姓名:<input type="text" name="username"/><br> <input type="submit"/> </form>
编写上传的api接口
@RequestMapping("/upload")
public String upload(MultipartFile myfile, HttpServletRequest request) throws IOException {
//1.获取保存文件的路径
String realPath = request.getSession().getServletContext().getRealPath("/images");
//2.根据上面的路径创建文件对象
File file=new File(realPath);
//3.判断该文件夹是否存在
if(!file.exists()){
file.mkdirs();
}
//4.获取上传文件的名称. 获取登录者ip+登录者id+登录者的时间戳
String filename = UUID.randomUUID().toString().replace("-","")+myfile.getOriginalFilename();
//5.把上传的文件保存到指定服务器下的路径。
File target=new File(realPath+"/"+filename);
myfile.transferTo(target);
System.out.println("上传成功");
return "main";
}
完成文件上传--文件保存到文件服务器

如果把文件存在本地服务器,服务器与服务器之间无法共享文件。我们需要一个专门存放文件的服务器。
可以自己搭建文件服务器[FastDFS Hadoop] 或者租第三方阿里云。