文件上传、下载(以CLOB形式存储)

之前遇到了这样一个需求,文件上传到数据库中以CLOB存储,并下载。还需支持JPG和PDF格式,百度了解之后就开工了。
说明,本次使用语言为JAVA语言,前台框架为EASYUI2.1,后台SpringMVC+Spring+mybatis前台,由表单发送。直接上代码

<form>
<input class=” easyui-filebox” id=”fj”/>  也可直接用原生file文本框
</form>

easyui-filebox可以很简单的同时上传多个文件,由后台接收
JS验证:(仅对文件类型做了验证,还可以根据fileText.length对文件大小验证)
v

ar fileText = $("#specialChangeFile").filebox('getText');
			var flag=meterReadRateSettingAdd.checkFile(fileText);
			if(!flag){
				API.alert('请上传文件或按格式要求上传!');
				return;
			}

checkFile:function(fileText){
			var flag = true;
			if(fileText == "") {
				flag=false;
			}
			var type = fileText.slice(fileText.lastIndexOf(".")+1,fileText.length);
			var checkType = type.toUpperCase();
			if(checkType !== "PDF"&&checkType !== "JPG"){  
				flag=false;
			};
			return flag;
			}

表单提交:(文件需同步传输,所以不能使用Ajax,我用的是异步表单提交,网上有ajaxFileUpload 的方法可以试试,原理类似)

var options = {
					dataType : "json",
					success : function(data) {
						
					},
					error : function(result) {
											}
			};
			if($("#formId").form('validate')==true){
				$('# formId).ajaxSubmit(options);
			}
  1. 后台
    (1)springMVC配置

(2)控制层接收文件
@RequestMapping(value="/xxx")
@ResponseBody
public Map<String, Object> xxx(@RequestParam(value = “fjFile”, required = false)MultipartFile fjFile)//如果是多文件上传,要用MultipartFile[] 接收
普通的流写入:

InputStream fileIs= null; 
fileIs= fjFile.getInputStream();
s=fjFile.getOriginalFilename();

注意:这里我做的需求是将文件以CLOB形式存储到本地数据库,所以需要将文件转为二进制,并进行二进制和String的特殊转换处理(主要针对图片和PDF等格式,直接转换会损坏文件),转换之后可以直接以CLOB形式入库

 byte[] byteFile = FileCopyUtils.copyToByteArray(fileIs);
indicatorExcludeSettingDto.setFj(byte2hex(byteFile));

/**
* 二进制转字符串
* @param b byte数组
* @return 二进制字符串
*/
public static String byte2hex(byte[] b){
StringBuffer sb = new StringBuffer();
String stmp = “”;
for (int n = 0; n < b.length; n++) {
stmp = Integer.toHexString(b[n] & 0XFF);
if (stmp.length() == 1) {
sb.append(“0” + stmp);
} else {
sb.append(stmp);
}
}
return sb.toString();

} 

读取:

OutputStream os = null;
    		ByteArrayInputStream bin=null;
    		try {
    response.setContentType("multipart/form-data"); 
                //处理下载弹出框名字的编码问题
                response.setHeader("Content-Disposition", "attachment;fileName=\"" + new String(file.getFileName.getBytes ("gb2312"), "ISO8859-1" )+file.getFjlx()+ "\"");
                os = response.getOutputStream();
                bin = new ByteArrayInputStream(hex2byte(file.getFj()));
    	        int len=0;
    			byte[] buffer=new byte[1024];
    			while((len=bin.read(buffer))>0){
    				os.write(buffer,0,len);
    			}
    			os.flush();

当然,读取时也要进行转换。
/**
* 字符串转二进制
* @param str 字符串
* @return byte数组
*/

  public static byte[] hex2byte(String str) {  
        if (str == null)  
            return null;  
        str = str.trim();  
        int len = str.length();  
        if (len == 0 || len % 2 == 1)  
            return null;  
        byte[] b = new byte[len / 2];  
        try {  
            for (int i = 0; i < str.length(); i += 2) {  
                b[i / 2] = (byte) Integer.decode("0X" + str.substring(i, i + 2)).intValue();  
            }  
            return b;  
        } catch (Exception e) {  
            return null;  
        }  
    }   

至此,文件上传、下载并以CLOB形式存储到数据库便完成了,写出来还是很简单的。当时做的时候,没少被坑,尤其是字符串和二进制的转换,很关键。CLOB最大能存储4G,一般是能够用了,可以在SpringMVC配置里限制大小。系统图片操作多,有条件的公司,建议还是搭个图片服务器,既方便操作也可减轻数据库的压力。

接下来补充一个FTP上传下载的操作,由于历史原因(就是我也不清楚的原因),系统的所有文件导出功能都需要两次请求,而我们部署了20个节点,使用服务器本地上传下载又与后来配置的NGNIX的IPHASH算法冲突,鉴于此,我们决定导出均使用FTP服务器。导出格式为EXCLE,技术为POI的HSSF。

  1. 前台:Easyui导出官方文档:http://www.jeasyui.net/extension/204.html
  2. 算了,时隔二个月才写,忘完了,直接使用FTPCLIENT工具类吧,POI的使用可以参考官方文档

在这里插入图片描述

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值