附件上传——mysql blob类型的数据(springboot)1
作为一个初出茅庐的菜鸟,这几天做了一下附件的上传与下载,附件文件存储在mysql中,数据类型为blob。在此做一下总结。望指正。
一.先总结附件的上传。(实质是将文件传到controller,后处理成二进制数据 才能够保存到数据库blob数据中)
我的目的是将文件保存在mysql的某一条记录中,需要通过页面上传文件到后台。
1.通过页面进行文件的上传,使用ajax,通过form表单以formData来将文件上传,删除不必要的内容。
前台代码:<form id="file" method="post" action="{{url}}" enctype="multipart/form-data">
<div class="file-container">
<button type="button" onclick="">上传</button>
<input type="file" name="file" id="file1" onchange="loadFile(this.files[0])" style="position: absolute; top: 0; left: 0; opacity: 0">
</div>
<button class="btn btn-primary" id="excelImp" type="button">导入</button>
</form>
$('#excelImp').click(function(){
var formData = new FormData();
/*var formData = new FormData($("#file")[0]);*/ 序列化表单的一种做法,可以上传文件。
var file = $('#file1').get(0).files[0];
formData.append("id",rows[0].taskId)
formData.append("file",file)
$.ajax({
url : " ",
type : "POST",
data :formData,
async : false,
cache : false,
contentType : false,//必须false才会自动加上正确的Content-Type
processData : false,//必须false才会避开jQuery对 formdata 的默认处理.XMLHttpRequest会对 formdata 进行正确的处理.
success : function() {
},
error : function() {
}
})
})
解释一下,定义新的formData数据后,可以以键值对的形式,将想要传到后台的数据命名填入。
要想将表单数据和文件一起传入到后台接收,只需在form标签中的与数据相关的标签name属性一一对应,就可以传输!
后台代码:controller接受 参数与ajax的formData 的 key进行对应,例如@RequestParam(value = "file")MultipartFile file, @RequestParam(value = "id") String id
这样控制器就可以接收到文件和一个id。
控制器获取到文件和id后,我出现了一个问题:我项目使用的springboot和springcloud,在不同模块的调度过程中,使用了restTemplate将参数由前端模块的控制器
传到另一个模块的控制器,怎么尝试都无法直接将MultipartFile的文件传输,所以对其进行了处理,将file转成了字节数组,才进行了传递。(对于我来说,为了更保险, 我将字节数组转成了String 才进行的传输)。
String afile = null; InputStream ins = file.getInputStream(); byte[] buffer=new byte[1024];
int len=0; ByteArrayOutputStream bos=new ByteArrayOutputStream();
while((len=ins.read(buffer))!=-1){
bos.write(buffer,0,len);
} bos.flush(); byte data[] = bos.toByteArray(); afile= new String (data);
在实现类中接收到String 后,将其转成byte[] 通过jdbc对mysql的操作,将其插入到数据库中。
Connection con = null; Statement statement = null; Statement statement = null;
Class.forName(driver); con = DriverManager.getConnection(url,user,password);
String sql= "update XXX set XXX=?,XXX=?"+" where TASK_ID=?";
PreparedStatement pstmt = con.prepareStatement(sql);
pstmt.setBytes(1, data); data为file转换成的byte[]数组,可直接存入到blob类型的数据
pstmt.setString(2, taskReceiveAccessoryName);
pstmt.setString(3, id); pstmt.executeUpdate(); 最后关闭数据库的连接
附件上传——mysql blob类型的数据(springboot)1的更多相关文章
- 使用plupload做一个类似qq邮箱附件上传的效果
公司项目中使用的框架是springmvc+hibernate+spring,目前需要做一个类似qq邮箱附件上传的功能,暂时只是上传小类型的附件 处理过程和解决方案都需要添加附件,处理过程和解决方案都可 ...
- EBS开发附件上传和下载功能(转)
原文地址: EBS开发附件上传和下载功能 上传 Oracle ERP二次开发中使用的方式有两种,一是通过标准功能,在系统管理员中定义即可,不用写代码,就可以使几乎任何Form具有附件功能,具体参考系统 ...
- asp.net结合uploadify实现多附件上传
1.说明 uploadify是一款优秀jQuery插件,主要功能是批量上传文件.大多数同学对多附件上传感到棘手,现将asp.net结合uploadfiy如何实现批量上传附件给大家讲解一下,有什么不对的 ...
- 使用PreparedStatement向数据表中插入、修改、删除、获取Blob类型的数据
使用PreparedStatement向数据表中插入.修改.删除.获取Blob类型的数据 2014-09-07 20:17 Blob介绍 BLOB类型的字段用于存储二进制数据 MySQL中,BLOB是 ...
- java 附件上传、下载前后端代码
前言:业务需要:附件上传,需要同时满足浏览器上传,和APP上传附件,并且浏览器端不可使用form表单提交,因为表单提交无法直接获取返回值,除非刷新页面才可显示上传的附件.所以此处使用ajaxfileu ...
- 彻底解决DZ大附件上传问题
个. 注意:很多人遇到修改php.ini后重应WEB服务后仍然不能生效.这种情况应该先确认一下所改的php.ini是不是当前PHP所使用的.您可以在WEB目录下建立一个php文件,内容很简单就一句话& ...
- Ajax实现附件上传
前两篇文章有介绍使用form.submit 实现附件的上传,但是这种方式使用起来很不方便,如过需要再上传成功以后执行一些其他的操作的时候比较麻烦.下面我为大家介绍下使用ajax实现附件上传的功能: 1 ...
- fsLayuiPlugin附件上传使用说明
fsLayuiPlugin 是一个基于layui的快速开发插件,支持数据表格增删改查操作,提供通用的组件,通过配置html实现数据请求,减少前端js重复开发的工作. GitHub下载 码云下载 测试环 ...
- httpclient 多附件上传
多附件上传实例: /** * 多附件上传 * @param host * @param uri * @param attachment 附件 * @param param body参数 * @retu ...
随机推荐
- 浅谈回归Regression(一)
一.什么是回归? 孩子的身高是否与父母有关? 实际上,父母和孩子的身高是受到回归效应影响的.在时间纵轴上受影响.具有随机性的事物,无不遵循这一规律. 只要数据足够大,人类的身高或者智商,都有趋于平均值 ...
- DELPHI SOKET 编程--使用TServerSocket和TClientSocket
本文采用delphi7+TServerSocket+TClientSocket; 笔者在工作中遇到对局域网中各工作站与服务器之间进行Socket通信的问题.现在将本人总结出来的TServerSocke ...
- Springmvc ajax跨域请求处理
上次给一个网站写网站 前后端分离 最后跪在ajax跨域上面了 自己在网上找了个方法 亲试可用 记录一下 写一个类 继承HandlerInterceptorAdapter package co ...
- dubbox源码分析(一)-服务的启动与初始化
程序猿成长之路少不了要学习和分析源码的.最近难得能静得下心来,就针对dubbox为目标开始进行源码分析. [服务提供方] 步骤 调用顺序 备注 容器启动 com.alibaba.dubbo.conta ...
- sql 嵌套查询
sql 某一字段 数量大于1 SELECT * FROM ecm_goods_spec AWHERE ( SELECT count( * ) FROM ecm_goods_spec BWHERE A. ...
- oam系统安装,windows操作系统注册列表影响系统安装
windows注册列表可能会影响到系统的安装,本次安装oam10g版本,安装后没有问题,但是在配置oam和weblogic portal单点登录时在weblogic portal中访问oid和oam的 ...
- Zabbix监控mysql主从状态并实现报警
一.环境需求 主机A: zabbix-server 主机B: zabbix-agent/mysql从 二.主机B操作 1.添加监控脚本 vim /data/zabbix/mysql_slave_che ...
- 【Asp.Net MVC】asp.net mvc Model验证总结及常用正则表达式
转自:http://www.cnblogs.com/easy5weikai/p/3843131.html 关于Model验证官方资料: http://msdn.microsoft.com/zh-cn/ ...
- 经典优秀屏幕截图录像工具FastStone Capture推荐
FastStone Capture (FSCapture) 是经典好用的屏幕截图软件,还具有图像编辑和屏幕录制两大功能. FastStone Capture 主要功能 包括:1.截图功能(可以捕捉:活 ...
- How to update BOL entity property value via ABAP code
Suppose I have one product with ID I042416 which could be found in CRM WebClient UI: I would like to ...