bootstrap-fileinput文件上传&后台接收处理

bootstrap-fileinput文件上传&后台接收处理使用bootstrap-fileinput进行文件上传,bootstrap提供了吩咐的API属性、方法、事件;控制文件上传每一个环境,提供各个部分的`class`。Java上传图片处理以及nodeJS上传文件处理。

大家好,又见面了,我是你们的朋友全栈君。

使用bootstrap-fileinput进行文件上传,有丰富的属性、方法、事件,还有好多demo供参考。

前端处理

直接上代码,简单明了。

	<div class="col-md-9 input-group">
  		<input type="file" name="file"  id="imgUpload" class="imgFile form-control">
  	</div>

这是原始的HTML文件上传时的设置;然后使用bootstrap-fileinput渲染它。

$("#imgUpload")
      .fileinput({
        language: "zh", //设置语言
        uploadUrl: url + "/upload/addImg", //上传的地址
        allowedFileExtensions: ["jpg", "png", "jpeg", "bmp"], //接收的文件后缀
        theme: "fa",      // 主题设置
        initialPreview: url1 + filePath + fileName,        // 初始预览区域显示的图片
        initialPreviewAsData: true,
        initialPreviewConfig: [
          { type: "image", fileType: "image", caption: fileName }
        ],
        dropZoneEnabled: false,          // 禁止点击预览区域进行文件上传操作
        maxFileCount: 1,                    // 最大上传为 1
        showUpload: false,             // 不显示上传按钮,选择后直接上传
        previewClass:"uploadPreview",
      })
      .on("change", function() {               
        // 清除掉上次上传的图片
        $(".uploadPreview").find(".file-preview-frame:first").remove();
		$(".uploadPreview").find(".kv-zoom-cache:first").remove();
      })
      .on("filebatchselected", function(e, files) {        
        $(this).fileinput("upload");             // 文件选择完直接调用上传方法。
      })
      .on("fileuploaded", function(e, data, previewiId, index) {       // 上传完成后的处理
        var form = data.form,
          files = data.files,
          extra = data.extra,
          response = data.response,        // 响应
          reader = data.reader;          // 文件对象
        if (response.flag) {
          let img = new Image();     // 这里上传的是图片,对图片处理获取图片的分辨率
          img.src = reader.result;
          if (img.complete) {
            $(this).attr("data-displayReso", img.width + "*" + img.height);
          } else {
            img.onload = function() {
              $(this).attr("data-displayReso", img.width + "*" + img.height);
            };
          }
        }
      });

注意
手动调用上传upload方法后,相关的一些事件则不生效。

  1. 进行多文件上传,<input type="file" name="file" id="imgUpload" class="imgFile form-control" multiple> ,设置属性maxFileCount 文件的最大数量。
  2. 进行单文件上传时,上传后再次选择文件上传,之前上传的还在,需要在change事件中手动清除之前的图片占位。设置属性previewClass
java 处理文件接收
@RequestMapping(value="/addImg",method={RequestMethod.POST})
@ResponseBody
public Map<String,Object> addImg(HttpServletRequest request, HttpServletResponse response){
	Map<String,Object> result= new HashMap<String, Object>();
	
	// 转型为MultipartHttpRequest:
	MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
	// 获得文件:
	MultipartFile file= multipartRequest.getFile("file");
	try(){
		if(!(imgFile.getOriginalFilename() == null || "".equals(imgFile.getOriginalFilename()))){
			String imgDir = "E:\\images";        // 图片上传地址
			// 对文件进行存储处理
			byte[] bytes = file.getBytes();
            Path path = Paths.get(imgDir,"\\"+file.getOriginalFilename());
            Files.write(path,bytes);

            result.put("msg","上传成功!");
            result.put("result",true);
		}
	}catch(IOException e){
            result.put("msg","出错了");
            result.put("result",false);
            e.printStackTrace();
        }catch (Exception e1){
            e1.printStackTrace();
        }
	return result;
}
	

划重点
MultipartFile imgFile = multipartRequest.getFile("file");这里的file 指的是前端input标签中的name属性.之前没注意到导致前台上传文件时报500错误。

multipartRequest属性对象

nodeJS处理文件上传

使用express框架搭建服务,使用formidable模块处理文件,要使用到NodeAPIfs文件系统和path路径。

app.post("/upload/addImg", function (req, res) {
	var form = new formidable.IncomingForm();
	form.encoding = 'utf-8';
	form.uploadDir = path.join(__dirname, 'tmp');       // 临时文件存储地址,之后进行重命名移动
	form.keepExtensions = true; // 文件扩展名

	form.parse(req, function (err, fields, files) {
		var filepath = '';
		for (var key in files) {
			if (files[key].path && filepath == '') {
				filepath = files[key].path;        // 获取到临时存放的文件地址
				break;
			}
		}
		var targetDir = path.join(__dirname, "/upload/imgs/");
		// 创建存放文件的目录
		if (fs.existsSync(targetDir)) {
			fs.mkdir(targetDir, {
				recursive: true
			}, (err) => {
				if (err) throw err;
			});
		}
		var fileExt = filepath.substring(filepath.lastIndexOf("."));
		// 文件类型校验
		if ((".jpg.png.bmp.jpeg").indexOf(fileExt.toLowerCase()) == -1) {
			var errType = new Error("此文件类型不支持!");
			res.json({
				code: -1,
				message: errType
			});
		} else {
			var filename = new Date().getTime() + fileExt;
			var targetFile = path.join(targetDir, filename);
			fs.rename(filepath, targetFile, err => {
				if (err) {
					console.info(err);
					res.json({
						code: -1,
						message: "操作失败"
					});
				} else {
					// 上传成功后处理返回文件的地址
					var fileUrl = path.join(__dirname, '/upload/imgs/' + filename);
					res.json({
						code: 200,
						fileUrl: fileUrl
					});
				}
			});
		}
	});
 });

注意
文件创建目录会出错,Error: ENOENT: no such file or directory,最好手动在指定路径下创建好存放的地址。

// 创建存放文件的目录
if (fs.existsSync(targetDir)) {
			fs.mkdir(targetDir, {
				recursive: true
			}, (err) => {
				if (err) throw err;
			});
		}

files文件对象:
files对象


2019-02-28 更新:补全Java存储路径部分代码

  1. 补全代码查看Java处理文件代码部分。

  2. 上传处理成功后,返回给前端结果时附带图片信息

     File file1=new File(path.toString());
     InputStream ins = new FileInputStream(file1);
     // 返回图片的地址,宽、高
     BufferedImage bufferedImage = ImageIO.read(ins);
     extData.put("imgUrl", path.toString());
     extData.put("imgW",bufferedImage.getWidth());
     extData.put("imgH",bufferedImage.getHeight());
     
     ins.close();
     ins=null;
     BufferedImage=null;
    

在使用form表单上传文件时,注意属性enctype="multipart/form-data"

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/133746.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Mysql经典练习题50题「建议收藏」

    Mysql经典练习题50题「建议收藏」网上关于这套练习题较多使用的是比较老的mysql版本,我使用的是Serverversion:8.0.15MySQL练习数据数据表–1.学生表Student(SId,Sname,Sage,Ssex)–SId学生编号,Sname学生姓名,Sage出生年月,Ssex学生性别–2.课程表Course(CId,Cname,TId)–CId–课程编号,Cna…

    2022年9月18日
    3
  • Android程序员如何制定自己的职业规划,拒绝做码农[通俗易懂]

    Android程序员如何制定自己的职业规划,拒绝做码农[通俗易懂]无论是程序员还是任何其他的职业,我认为都应该有清晰长远的职业规划。虽然说计划没有变化快,但如果没有计划就更谈不上计划了。没有职业规划的人,在工作上基本都是为了完成任务而做,很难得到提升,因为没有目标,所以人就是一种得过且过的状态。所以作为一个有眼光的人,应该有自己长远的职业规划,即使没有长远的职业规划,也应该有短期的规划,这样人做事才有动力,有目标。程序员一直都是一个热门话题,因为工资比较高,…

    2022年4月28日
    168
  • gain command of_partitioning

    gain command of_partitioning今天在Centos上进行硬盘分区的时候,分区完成时候需要命令partprobe指令来通知一下内核我刚才进行了系统分区,但是执行的时候发现Centos最小化安装之后没有这个命令,第一时间想到的就是肯定是包含这个指令的rpm包没有装,然后就跑到Centos7上面看一下有没有这条指令,发现有这条指令,然后就查看一下这条指令是来自于哪个安装包[root@zsf~]#whichp…

    2022年10月8日
    4
  • Java面试题总结(附答案)「建议收藏」

    Java面试题总结(附答案)「建议收藏」2012年毕业,2016年转行,没有一个体面的工作,机缘巧合之下,来到了大连,Java培训,一个全新的领域,迷茫、困惑、漫无目的的努力,转行真的被歧视,真的不行吗?我命由我不由天,我觉得我行!相信我,只要你足够努力,总有成为架构师,独挡一面的一天。最近参加了一些面试,效果不是很理想,项目介绍只有大框,没有突出重点,没有项目中的具体细节,因为都是看的B站视频,实际工作中都是在做重复的CRUD工作,愁人啊。618买的新书塑料还没拆!视频计划已经执行到第二篇了!熬夜学习,是刻苦奋斗还是自欺欺人?面试

    2022年7月18日
    18
  • Mysql java JDBC驱动jar包

    Mysql java JDBC驱动jar包mysql-connector-java-8.11.tar.gzmysql-connector-java-8.0.11.zip说明:在学习Hive时,需要用mysql存储元数据,需要用到java的mysql驱动包,需要可以拿取,都是"京斗码农",相互学习、相互贡献。链接:https://pan.baidu.com/s/1YRLx3Nle3ByG8OmmcnuODQ密码:hsq1…

    2022年5月21日
    40
  • bcd码与十进制转换方法_5421bcd码转换十进制

    bcd码与十进制转换方法_5421bcd码转换十进制BCD码其实就是之前在数字电路中说的用4位二进制数值来表示一个0-9中的数字,例如:0000=00001=10010=20011=3也就是说如果把一个数字作为一个BCD码,例如:112

    2022年8月6日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号