最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

使用elementUI实现将图片上传到本地的示例

来源:动视网 责编:小采 时间:2020-11-27 22:08:31
文档

使用elementUI实现将图片上传到本地的示例

使用elementUI实现将图片上传到本地的示例:查阅饿了吗官方文档可以了解上传组件的使用方法。http://element.eleme.io/#/zh-CN/component/upload 前台的页面代码为: <el-upload class=upload-demo ref=upload action=http://127.0.0.1:20001/Ad
推荐度:
导读使用elementUI实现将图片上传到本地的示例:查阅饿了吗官方文档可以了解上传组件的使用方法。http://element.eleme.io/#/zh-CN/component/upload 前台的页面代码为: <el-upload class=upload-demo ref=upload action=http://127.0.0.1:20001/Ad


查阅饿了吗官方文档可以了解上传组件的使用方法。http://element.eleme.io/#/zh-CN/component/upload

前台的页面代码为:

<el-upload
 class="upload-demo"
 ref="upload"
 action="http://127.0.0.1:20001/Administration/MediaApiLhUploadHandler"
 :on-preview="handlePreview"
 :on-remove="handleRemove"
 :file-list="fileList"
 :auto-upload="false"
 >
 <el-button slot="trigger" size="small" type="primary">选取文件</el-button>
 <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button>
 </el-upload>

具体的绑定method的方法见官方文档

上传到本地,需要在后台建立一个接口进行接收,接口代码如下:

@Override
	public void handle(List<FileItem> fileItemList, NetUpMediaapiImgUpload up, NetDownMediaapiImgUpload down, HttpServletResponse response) {
	System.out.println("path:"+getBasePath());
	if (!CommUtil.isEmpityList(fileItemList)) {
	List<String> paths=new ArrayList();
	for (FileItem fileItem : fileItemList) {
	String path = writeFile(fileItem);
	paths.add("../../static/img/"+fileItem.getName());//浏览器不允许使用绝对路径
	logger.info("上传成功:" + path);
	logger.info("更新数据");
	}
	down.setAllPath(paths);
 
	}
	}
 
	public static String writeFile(FileItem file){
	String fileName = getFileName(file.getName());
	fileName = formatFileName(fileName);
	fileName = getFilePrefix(fileName)+'.'+getFileSuffix(fileName);
	String path = getBasePath()+"/xmob-web/static/img/";
	//path="E:\\xmob\\trunk\\xmob-web\\static\\img\\";//图片应该放在WEB文件夹的static目录下
	File desFile = new File(path);
	if (!desFile .exists() && !desFile .isDirectory()) {
	System.out.println("//不存在");
	desFile .mkdir();
	}
	String result = null;
	try {
	InputStream in = file.getInputStream();
	FileOutputStream out = new FileOutputStream(path+"/"+fileName);
	//创建一个缓冲区
	byte buffer[] = new byte[1024];
	//判断输入流中的数据是否已经读完的标识
	int len = 0;
	//循环将输入流读入到缓冲区当中,(len=in.read(buffer))>0就表示in里面还有数据
	while((len=in.read(buffer))>0){
	//使用FileOutputStream
输出流将缓冲区的数据写入到指定的目录(path)当中 out.write(buffer, 0, len); } in.close(); out.close(); //删除处理文件上传时生成的临时文件 file.delete(); result = path+"/"+fileName; } catch (Exception e) { e.printStackTrace(); } return result; } /** * 获取资源路径 * @return */ private static String getBasePath(){ String template_dir = System.getProperty("user.dir"); return template_dir.substring(0,template_dir.lastIndexOf(File.separator)); } /** * 注意:不同的浏览器提交的文件名是不一样的,有些浏览器提交上来的文件名是带有路径的,如: c:\a\b\1.txt,而有些只是单纯的文件名,如:1.txt * 处理获取到的上传文件的文件名的路径部分,只保留文件名部分 * @param fileName * @return */ private static String getFileName(String fileName){ fileName = fileName.substring(fileName.lastIndexOf(File.separator)+1); return fileName; } /** * 格式化文件名 * @param fileName * @return */ private static String formatFileName(String fileName){ String[] sArr = fileName.split("\\."); String str = sArr[0]; str = str.replaceAll(" ", ""); str = str.replaceAll("\\s+|_", "-"); String result = str+"."+sArr[1]; return result; } /** * 获得文件名前缀 */ private static String getFilePrefix(String fileName){ fileName = formatFileName(fileName); String[] sArr = fileName.split("\\."); return sArr[0]; } /** * 获得文件名后缀 */ private static String getFileSuffix(String fileName){ fileName = formatFileName(fileName); String[] sArr = fileName.split("\\."); return sArr[1]; }

以上这篇使用elementUI实现将图片上传到本地的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

文档

使用elementUI实现将图片上传到本地的示例

使用elementUI实现将图片上传到本地的示例:查阅饿了吗官方文档可以了解上传组件的使用方法。http://element.eleme.io/#/zh-CN/component/upload 前台的页面代码为: <el-upload class=upload-demo ref=upload action=http://127.0.0.1:20001/Ad
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top