1.文件下載 用ResponseEntity<byte[]> 返回值完成文件下載 具體參見本博客之前的《文件上傳下載》 2.自定義攔截器 Spring MVC也可以使用攔截器對請求進行攔截處理,用戶可以自定義攔截器來實現特定的功能,自定義的攔截器必 須實現HandlerInterceptor介面 1 ...
1.文件下載
用ResponseEntity<byte[]> 返回值完成文件下載
具體參見本博客之前的《文件上傳下載》
@RequestMapping(value="/testResponseEntity") public ResponseEntity<byte[]> testResponseEntity(HttpServletRequest request) throws Exception{ ServletContext servletContext = request.getServletContext(); String fileName = "風吹麥浪.mp3"; String realPath = servletContext.getRealPath("/WEB-INF/"+fileName); InputStream in = new FileInputStream(new File(realPath)); byte[] body = new byte[in.available()]; in.read(body); MultiValueMap<String, String> headers = new HttpHeaders(); fileName = new String(fileName.getBytes("gbk"),"iso8859-1"); headers.set("Content-Disposition", "attachment;folename="+fileName); HttpStatus statusCode = HttpStatus.OK; ResponseEntity<byte[]> response = new ResponseEntity<byte[]>(body, headers, statusCode); in.close(); return response; }
2.自定義攔截器
Spring MVC也可以使用攔截器對請求進行攔截處理,用戶可以自定義攔截器來實現特定的功能,自定義的攔截器必 須實現HandlerInterceptor介面 1).自定義實現類實現 HandlerInterceptor介面public class MyInterceptor implements HandlerInterceptor{ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("1-preHandle"); return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { System.out.println("1-postHandle"); } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { System.out.println("1-afterCompletion"); } }
三個方法
– preHandle():該方法在目標方法之前被調用, 若返回值為true,則繼續調用後續的攔截器和目標方法 若返回值為false,則不會再調用後續的攔截器和目標方法 可以考慮做許可權,日誌或者事務等! – postHandle():調用目標方法之後,但渲染視圖之前被調用 可以對請求域中的屬性或者視圖做出修改!– afterCompletion():渲染視圖之後被調用, 可以在該方法中進行一些資源清理的操作。
2).在springmvc配置文件中配置相對應的攔截器
<mvc:interceptors> <!--配置自定義攔截器 ,MyFilter都攔截 --> <bean class="com.neuedu.springmvc.filter.MyFilter"></bean> </mvc:interceptors>
若有多個攔截器
<mvc:interceptors> <bean class="com.neuedu.springmvc.interceptor.MyInterceptor"></bean> <mvc:interceptor> <mvc:mapping path="/**"/><!-- 都攔截 --> <mvc:exclude-mapping path="/testInterceptor"/><!-- 除了這個都攔截 --> <bean class="com.neuedu.springmvc.interceptor.BInterceptor"></bean> </mvc:interceptor> </mvc:interceptors>
<mvc:mapping path=" "/> 與 <mvc:exclude-mapping path=" "/> 連用
前者代表:都攔截
後者代表:除了這個都攔截
3.SpringMVC的異常處理
1.加上<mvc:annotation-driven>標簽: 2.在當前Handler中定義由@ExceptionHandler註解修飾的方法,用於處理異常信息! 註意: 1).@ExceptionHandler 方法修飾的入參中可以加入Exception類型的參數,該參數即對應發生的異常信息 2).@ExceptionHandler 方法的入參中不能傳入Map.若希望把異常信息傳到頁面上,需要使用ModelAndView作為方法的返回值@ExceptionHandler(value={ArithmeticException.class}) public ModelAndView handleException(Exception ex){ ModelAndView mv = new ModelAndView(); mv.setViewName("error"); mv.addObject("exception", ex); return mv; }3).@ExceptionHandler 註解定義的方法優先順序問題: 例如發生的是NullPointerException,但是聲明的異常有 RuntimeException 和 Exception,此候會根據異常的最近繼承關係找到繼承深度最淺的那個 @ExceptionHandler 註解方法,即標記了 RuntimeException 的方法 4).ExceptionHandlerMethodResolver 內部若找不到@ExceptionHandler 註解的話,會找@ControllerAdvice 中的@ExceptionHandler 註解方法
@ControllerAdvice public class HangleException { @ExceptionHandler(value={ArithmeticException.class}) public String handleException(){ System.out.println("no"); return "error"; } }
4,基於配置的異常處理
如果希望對所有異常進行統一處理,可以使用 SimpleMappingExceptionResolver,它將異常類名映射為視圖名,即發生異常時使用對應的視圖報告異常
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <!-- exceptionAttribute用於指定異常對象在request域中的鍵 --> <property name="exceptionAttribute" value="ex"></property> <property name="exceptionMappings"> <props> <!-- key:指定異常的全類名 value:出現錯誤後要轉發到的頁面,但是此處沒有value屬性,所以直接寫,如"error"--> <prop key="java.lang.ArithmeticException">error</prop> </props> </property> </bean>
在 jsp頁面寫 ${exception },會在頁面顯示錯誤信息
這是因為預設將該信息寫到 request 域中
如果不想用這個 名稱,可以在配置信息中添加
<property name="exceptionAttribute" value="ex"></property>
這樣在 jsp 頁面寫 ${ex } 也會在頁面顯示錯誤信息
單攔截器流程圖:
多攔截器流程圖: