SpringMVC学习(二)
1. 响应数据和结果视图
1.1 返回类型
a. 字符串类型
转发到该字符串解析得到的视图中,通过model对象将数据存放到request域中
@RequestMapping(path="/response") public String response(Model model){ user u = new user(); u.setAge(23); u.setName("lzr"); u.setSex("男"); model.addAttribute("user",u); //存入request域 return "success"; //转发到success.jsp }
b. void类型
默认转发到该类名和方法所指定的视图文件中
或者调用原生Servlet-api进行转发或重定向
c. modelandview
通过向modelandview对象设置数据和视图进行转发
@RequestMapping(path="/response") public ModelAndView response(){ user u = new user(); u.setAge(23); u.setName("lzr"); u.setSex("男"); ModelAndView mav = new ModelAndView(); mav.addObject(u); mav.setViewName("success"); return mav; }
1.2 ResponseBody响应josn数据
前端控制器会将静态资源拦截,需进行过滤:
<mvc:resources mapping="/css/**" location="/css/" ></mvc:resources> <!--过滤样式文件-->
<mvc:resources mapping="/js/**" location="/js/" ></mvc:resources> <!--过滤js文件-->
<mvc:resources mapping="/images/**" location="/images/" ></mvc:resources> <!--过滤图片文件-->
在进行异步请求时,采用**@RequestBody** 注解将ajax请求中的data封装到形参中。 采用@ResponseBody注解可以将返回的数据封装到Request域中。
2. 实现文件上传
2.1 传统web中的上传
文件上传的前提
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-qclGFxbv-1612276581980)(C:\Users\11252\AppData\Roaming\Typora\typora-user-images\image-20210202191617318.png)]
传统web中的文件上传:
@RequestMapping("/fileupload")
public String fileupload(HttpServletRequest request, HttpServletResponse response) throws Exception {
System.out.println("上传执行...");
// 获取存储文件路径
String path = request.getSession().getServletContext().getRealPath("/uploads/");
File file = new File(path);
// 判断是否存在该文件夹
if(!file.exists()){
file.mkdirs();
}
//获取磁盘文件项工厂
DiskFileItemFactory factory = new DiskFileItemFactory();
ServletFileUpload upload = new ServletFileUpload(factory);
//获取表单中的项
List<FileItem> items = upload.parseRequest(request);
for(FileItem fileItem: items){
if(fileItem.isFormField()){
System.out.println(fileItem.toString());
}else{
String filename = UUID.randomUUID().toString().replace("-", "")+fileItem.getName();
//上传文件
fileItem.write(new File(path, filename));
fileItem.delete();
}
}
return "success";
}
2.2 SpringMVC中的文件上传
- 配置文件解析器
<!-- 配置文件上传解析器 -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 设置上传文件的最大尺寸为5MB -->
<property name="maxUploadSize" value="5242880"></property>
</bean>
- 文件上传
@RequestMapping("/fileupload")
// MultipartFile参数名称必须和表单中的name一致
public String fileupload(HttpServletRequest request, MultipartFile upload) throws Exception {
System.out.println("上传执行...");
String path = request.getSession().getServletContext().getRealPath("/uploads/");
File file = new File(path);
if(!file.exists()){
file.mkdirs();
}
//执行上传
String filename = UUID.randomUUID().toString().replace("-", "")+upload.getOriginalFilename();
upload.transferTo(new File(path,filename));
return "success";
}
2.3 跨服务器文件上传
在实际开发中,我们会有很多处理不同功能的服务器。例如: 应用服务器:负责部署我们的应用 数据库服务器:运行我们的数据库 缓存和消息服务器:负责处理大并发访问的缓存和消息 文件服务器:负责存储用户上传文件的服务器。
导入jar包:
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-core</artifactId>
<version>1.18.1</version>
</dependency>
<dependency>
<groupId>com.sun.jersey</groupId>
<artifactId>jersey-client</artifactId>
<version>1.18,1</version>
</dependency>
@RequestMapping("/fileupload")
// MultipartFile参数名称必须和表单中的name一致
public String fileupload(MultipartFile upload) throws Exception {
String filename = UUID.randomUUID().toString().replace("-", "")+upload.getOriginalFilename().replaceAll("[\u4e00-\u9fa5]", "");
//定义上传服务器路径
String path = "http://localhost:9090/imageserver_war_exploded/uploads/";
//创建客户端对象
Client client = Client.create();
WebResource webResource = client.resource(path+filename);
webResource.put(upload.getBytes());
return "success";
}
注意:
报错409: 检查是否创建了目录
报错403/405:修改web.xml
报错404:服务器地址是否填写错误
报错400:检查传输文件名中是否有中文字符
3. SpringMVC中的异常处理
待更新。。。