JFinal框架单文件、多文件上传详解

简介

1.上一篇博客我们讲解了SSH框架之SpringMVC的文件上传代码,那么本片博客将会重点讲解JFinal国产框架的单文件、多文件上传;
  2.JFinal封装了所有的输入输出流,使用自身的类去处理上传的文件;
  3.JFinal在使用自身特性的同时,也包含提供了常用的处理文件的方法;
  4.本篇实例将会分成四个步骤,给您简单明了走完的JFinal文件上传的整个流程:
  (1).需要的jar包;
  (2).jsp页面;
  (3).config配置(jfinal框架不需要进行xml配置,全部配置可在java类的config类配置);
  (4).后台controller处理方法;

实例

1.需要提供的jar包:commons.fileupload-1.2.1.jar; commons.io-1.4.0.jar;cos-26Dec2008.jar;
  
  2.jsp页面:
  需要导入的js:jquery.form.js

<script type="text/javascript" src="jquery.form.js"></script>
    <script type="text/javascript"> 
             //单文件上传文件
             function uploadFile(){
                    var form = $("#uploadFile");  
                    var options  = {    
                        url:'Main/User/uploadFile',    
                        type:'post',
                        //data:{},    
                        success:function(data){
                           var htmlToJson = JSON.parse(data);
                           if(htmlToJson.ifSuccess=="success"){
                                  alert("文件上传成功!");
                           } 
                        }                          
                    };    
                       form.ajaxSubmit(options);                   
             }
             
             //多文件上传
             function moreUploadFile(){
                    var form = $("#moreFile");  
                    var options  = {    
                        url:'Main/User/moreUploadFile',    
                        type:'post',
                        //data:{},    
                        success:function(data){
                           var htmlToJson = JSON.parse(data);
                           if(htmlToJson.ifSuccess=="success"){
                                  alert("文件上传成功!");
                           } 
                        }                          
                    };    
                       form.ajaxSubmit(options);                   
             }
             
    </script>

    <form id="uploadFile" enctype="multipart/form-data">
        <span>文件上传:</span>
        <input type="file" id="fileText" name="fileText" placeholder="请选择文件"/><br><br>
        <span>测试其他的参数:</span>
        <input  name="otherValue" value="" placeholder="请输入其余参数"/>
        <a href="javascript:void(0)" onclick="uploadFile()" >上传</a>
    </form>  
    

    <form id="moreFile" enctype="multipart/form-data">
        <span>多文件上传:</span>
        <input type="file" name="moreFile" multiple="multiple" value="" placeholder="请选择文件"/><br><br>
        <a href="javascript:void(0)" onclick="moreUploadFile()" >上传</a>
    </form>     

<!--注意:要在form标签中加上enctype="multipart/form-data"表示该表单是要处理文件的,

这是最基本的东西,很多人会忘记然而当上传出错后则去找程序的错误,却忘了这一点 -->

3.config的java类配置:

import com.jfinal.config.Constants;
import com.jfinal.config.Handlers;
import com.jfinal.config.Interceptors;
import com.jfinal.config.JFinalConfig;
import com.jfinal.config.Plugins;
import com.jfinal.config.Routes;
import com.jfinal.ext.handler.ContextPathHandler;
import com.jfinal.plugin.activerecord.CaseInsensitiveContainerFactory;
import com.jfinal.plugin.activerecord.dialect.MysqlDialect;
import com.jfinal.plugin.c3p0.C3p0Plugin;
import com.jfinal.render.ViewType;
import com.jfinal.template.Engine;
import com.alan.core.jfinal.plugin.AutoTableBindPlugin;
import com.alan.core.jfinal.plugin.MyRoutesUtil;
import com.alan.core.jfinal.plugin.TableNameStyle;
import com.alan.interceptor.PermitInterceptor;

/**
 * @author hqc
 * API引导式配置
 * 这里只是进行简单配置,其余的详细配置可参考官网
 */
public class JFWebConfig extends JFinalConfig {
	/** 
	*配置全局变量
	*/
	public static int pageSize = 20;
	public static String saveDirectory = ""; // 上传文件目录,默认为upload
	public static int maxPostSize = 1024 * 1024 * 1024; // 默认上传文件大小 1G


	/** 
	*配置常量 
	*/
	public void configConstant(Constants me) {
        me.setBaseUploadPath("upload");        //设置文件上传默认路径
	}

}

4.后台controller处理方法:

	/**单文件上传
	 * 1. getFile(String parameterName, String uploadPath);
	 * 2. uploadPath参数会指定上传路径,但其指定的前提是基础路径,upload,也就是说指定file路径,然后上传的文件的路径为upload/file;
	 * 3. 文件上传的基本路径可以在常量进行配置
	 * 
	 */
	public void uploadFile(){ 
		/*使用UploadFile获取前台文件
		*第一个参数是页面file的name名,第二个参数是指定保存的文件夹,第三个参数是设置文件的最大值,第四个参数是设置文件的编码方式
		*UploadFile  upFile = getFile("fileText", filedir); //或getFile(getPara("fileText"), filedir); 
		*/
		private final int maxSize = 100 * 1024 * 1024;
		private String filedir=PathKit.getWebRootPath()+"/text";
		UploadFile  upFile = getFile("fileText",filedir,maxSize,"UTF-8");
		
		/*对文件进行重命名
		*upFile.getFile().renameTo(dest);可使用file的原生方法去对file进行重命名,
		*jf3.1版本已经添加自定义名称功能,所以这个适合3.1之前的版本使用;
	    *根据原文件名使用时间戳和随机数重命名,保存,原来的临时文件会自动删除
		*/
		SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddhhmmss");
	    String fileName = upFile.getFileName();
	    String lastThreeLetter = fileName.substring(fileName.lastIndexOf("."));
	    String sqlName = sdf.format(new Date())+(int)(Math.random()*10000)+lastThreeLetter;
		upFile.getFile().renameTo(new File(PathKit.getWebRootPath()+"/upload/file/"+sqlName));
		
		/*
		*上传文件的同时,如果包含其他的携带的变量 的话需要先使用getFile方法,之后才能获取其他的变量参数
		*/
		String otherParameter = getPara("otherValue");
		System.out.println("获取到的额外的参数:"+otherParameter);

		/*
		 * jf后台在获取文件的时候可直接获取文件文件的修改名称、原名称、上传保存的路径
		 *(getUploadPath(),不包含文件,只到达文件夹;getFile()能够直接获取到文件,包括文件名)、
		 * 文件的类型(例如jpeg文件格式,获取到的是image/jpeg)
		 */
		System.out.println("1:"+upFile.getFileName()+" 2:"+upFile.getOriginalFileName()+" 3:"+upFile.getUploadPath());
		System.out.println("文件:"+upFile.getFile()+" 4:"+upFile.getContentType());
		
		/*
		 * jf获取文件根路径的方法:
		 */
		String path = PathKit.getWebRootPath();
		System.out.println(path);
		
		/*
		 * 1.返回的是text/html,前台需使用json工具转换成json对象才能获取数据,var htmlToJson = JSON.parse(data);
		 * 2.如果不包含文件上传的form表单提交异步刷新,则直接使用renderJSON(params);
		 */
		String params = "{\"ifSuccess\":\"success\"}";
		render(new JsonRender(params).forIE());
		
	}

	/**多文件上传
	*多文件上传需要在src下面添加com.oreilly.servlet包,添加MultipartRequest.java的类,用于处理多文件重命名问题
	*/
	public void moreUploadFile(){ 

	    //统一上传到默认的项目根目录
		List<UploadFile>  upFile = getFiles("file");
		
		//循环遍历获取文件重命名,如果不需要重命名则无需此步骤
		SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddhhmmss");
		String formatTime = sdf.format(new Date());
		for(UploadFile upf: upFile){
			System.out.println("循环获取文件名:"+upf.getFileName());
		    //根据原文件名使用时间戳和随机数重命名,保存,原来的临时文件会自动删除
		    String fileName = upf.getFileName();
		    String lastThreeLetter = fileName.substring(fileName.lastIndexOf("."));
		    String sqlName =formatTime + (int)(Math.random()*10000)+lastThreeLetter;
		    upf.getFile().renameTo(new File(PathKit.getWebRootPath()+"/upload/file/"+sqlName));
		}

		System.out.println("集合长度:"+upFile.size());
		String params = "{\"ifSuccess\":\"success\"}";
		render(new JsonRender(params).forIE());
	}

总结

1.以上就是JFinal上传文件的全部流程,代码也是简洁方便,对于还不是很了解JFinal上传文件的程序猿还是有帮助的,有需要的可以自行复制代码,然后可以经过自己的进一步加工,形成对自己最有效的一套代码;

2.JFinal作为国产的优秀框架,不论是在处理上传文件方面,还是在其他的config配置、AOP拦截、数据库连接池等方面都是很优秀的,有兴趣的童鞋可多去了解学习一下这个框架;
     
  3.实践是检验认识真理的唯一标准,代码好不好用,何不亲自动手实践看看;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值