图片上传到mysql_图片上传到数据库的总结

转眼间在博客园里待了快一年了,我还能记得去年的这个时候老师有个项目,在这个项目里需要把图片保存到数据库里,以前我做的就是把路径保存到数据库,后来为了实现这个功能我可是费了不少劲啊,问东问西的最后还是在CSDN网友的帮助下完成了。今天晚上又有CSDN网友提问有关图片保存到数据库的问题。下面我来汇总一下如何将图片保存到SqlServer、Oracle、Access数据库中。

首先,我们要明白图片是以二进制的形式保存在数据库中的,那么把图片保存到数据库中的步骤大体上有这几步

1.将图片转换为二进制数组(byte[]);

2.把转换后的二进制数组(byte[])作为参数传递给要执行的Command;

3.执行Command;

首先,如何把图片转换成byte[],如果你使用的是ASP.Net2.0,那么你可以使用FileUpLoad控件来实现

byte[] fileData = this.FileUpload1.FileBytes;

如果你用的是ASP.Net1.1或者你在创建WinForm那么你可以使用下面的方法来把图片转换为byte[]

731655954c7be9d8835ece551b5385f8.pngpublicbyte[] getBytes(stringfilePath)

24a924a57ba6b3f2b51fc9edb7ea4186.png

9310e85a14af99de4811ff4c77f1f911.png222530190136c9c4cfd237cc0d5cff99.png{

1408c5260b2f05e450dee929db9be5f7.png    System.IO.FileStream fs=newSystem.IO.FileStream(filePath, System.IO.FileMode.Open);

1408c5260b2f05e450dee929db9be5f7.pngbyte[] imgData=newbyte[fs.Length];

1408c5260b2f05e450dee929db9be5f7.png    fs.Read(imgData,0, (int)fs.Length);

1408c5260b2f05e450dee929db9be5f7.pngreturnimgData;

f466905a3bcb5dcef110eab799825254.png}接下来我们要做的就是要把已经得到的byte[]作为参数传递给Command对象

1.SqlServer数据库。SqlServer有Image字段类型,最大可以存储2G的数据。

731655954c7be9d8835ece551b5385f8.pngbyte[] fileData=this.FileUpload1.FileBytes;

731655954c7be9d8835ece551b5385f8.png

731655954c7be9d8835ece551b5385f8.pngstringsql="insert into t_img(img) values (@img)";

731655954c7be9d8835ece551b5385f8.pngstringstrconn=System.Configuration.ConfigurationManager.ConnectionStrings["fengdongDB"].ToString();

731655954c7be9d8835ece551b5385f8.pngSqlConnection sqlConn=newSqlConnection(strconn);

731655954c7be9d8835ece551b5385f8.pngSqlCommand sqlCo

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将文件上传MySQL数据库,需要先将文件转换成二进制数据,然后将其插入到数据库中的BLOB类型字段中。以下是使用Layui上传图片并将其存入MySQL数据库的示例: 1. 在HTML中添加文件上传表单: ```html <form class="layui-form" action="" enctype="multipart/form-data"> <div class="layui-form-item"> <div class="layui-upload"> <button type="button" class="layui-btn" id="uploadBtn">上传图片</button> <div class="layui-upload-list"> <img class="layui-upload-img" id="previewImg"> <p id="previewText"></p> </div> </div> </div> </form> ``` 2. 引入Layui和jQuery库: ```html <link rel="stylesheet" href="https://cdn.staticfile.org/layui/2.5.6/css/layui.min.css"> <script src="https://cdn.staticfile.org/jquery/3.5.1/jquery.min.js"></script> <script src="https://cdn.staticfile.org/layui/2.5.6/layui.min.js"></script> ``` 3. 初始化Layui上传组件: ```javascript layui.use('upload', function(){ var upload = layui.upload; //执行上传 var uploadInst = upload.render({ elem: '#uploadBtn', //绑定元素 url: '/upload/', //上传接口 accept: 'images', //允许上传的文件类型 size: 1024, //限制文件大小,单位KB done: function(res){ //上传成功回调 $('#previewImg').attr('src', res.data.src); //显示预览图 $('#previewText').html(res.data.title); //显示文件名 //将文件二进制数据存入数据库 $.ajax({ type: 'POST', url: '/saveToDB/', data: { imageData: res.data.imageData //文件的二进制数据 }, success: function(data){ console.log(data); }, error: function(){ console.log('上传失败'); } }); }, error: function(){ //上传失败回调 console.log('上传失败'); } }); }); ``` 4. 在服务器端处理上传的文件,并将其存入MySQL数据库: ```php <?php //获取上传的文件二进制数据 $imageData = file_get_contents($_FILES['file']['tmp_name']); //连接MySQL数据库 $servername = "localhost"; $username = "username"; $password = "password"; $dbname = "dbname"; $conn = new mysqli($servername, $username, $password, $dbname); //将文件二进制数据插入到数据库中 $stmt = $conn->prepare("INSERT INTO images (image_data) VALUES (?)"); $stmt->bind_param("b", $imageData); $stmt->execute(); $stmt->close(); $conn->close(); ?> ``` 注意:以上代码仅供参考,具体实现需要根据自己的实际情况进行调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值