springMVC--文件上传

文件上传

1、导入jar

跨服务器上传文件jar。Io,fileupload

springMVC--文件上传_第1张图片

 

需求

上传图片,图片里面回显。Ajax。页面不刷新图片回显。

Ajax能不能提交表单?

 

//把文件关联表单

//触发ajax事件

springMVC--文件上传_第2张图片

模拟2台服务器:

创建一个项目,图片服务器项目,图片服务器和上传图片的项目端口不一致。

springMVC--文件上传_第3张图片

2、开启文件上传

Springmvc配置文件配置支持文件上传类:


	
	
	

3、页面ajax

发送请求,上传图片:图片被关联表单。提交表单:jquery.form.js




4、uploadController

使用jersy服务器进行跨服务器上传:

package cn.itcast.controller;

import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

import cn.itcast.utils.Commons;

import com.sun.jersey.api.client.Client;
import com.sun.jersey.api.client.WebResource;

@Controller
@RequestMapping("/upload")
public class UploadController {

	@RequestMapping("uploadPic")
	public void uploadPic(HttpServletRequest request,String fileName,PrintWriter out){
		//把Request强转成多部件请求对象
		MultipartHttpServletRequest mh = (MultipartHttpServletRequest) request;
		//根据文件名称获取文件对象
		CommonsMultipartFile cm = (CommonsMultipartFile) mh.getFile(fileName);
		//获取文件上传流
		byte[] fbytes = cm.getBytes();
		
		//文件名称在服务器有可能重复?
		String newFileName="";
		SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS");
		newFileName = sdf.format(new Date());
		
		Random r = new Random();
		
		for(int i =0 ;i<3;i++){
			newFileName=newFileName+r.nextInt(10);
		}
		
		//获取文件扩展名
		String originalFilename = cm.getOriginalFilename();
		String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
		
		//创建jesy服务器,进行跨服务器上传
		Client client = Client.create();
		//把文件关联到远程服务器
		WebResource resource = client.resource(Commons.PIC_HOST+"/upload/"+newFileName+suffix);
		//上传
		resource.put(String.class, fbytes);
		
		
		//ajax回调函数需要会写写什么东西?
		//图片需要回显:需要图片完整路径
		//数据库保存图片的相对路径.
		String fullPath = Commons.PIC_HOST+"/upload/"+newFileName+suffix;
		
		String relativePath="/upload/"+newFileName+suffix;
		//{"":"","":""}
		String result="{\"fullPath\":\""+fullPath+"\",\"relativePath\":\""+relativePath+"\"}";
		
		out.print(result);
				
		
	}
	
}

5、修改图片服务器文件上传权限

springMVC--文件上传_第4张图片


6、图片上传位置

springMVC--文件上传_第5张图片


你可能感兴趣的:(JavaEE,springmvc)