数据库添加图片路径异常

工具:SQLServer2012    Visual Studio 2013

情况:在pictureBox控件中添加照片 然后在保存在数据库中 

        我这样写的

        出现错误是:

  ps:(数据库中有image的类型,因存放的照片要是太多的话,会增加数据库的负担,因此保存图片的路径)

解决办法:

原因:是因为pictureBox1.Imagelocation是null 的

      修改代码:

if (pictureBox1.Image != null)
{
if (pictureBox1.ImageLocation == null)
{
paras.Add(new SqlParameter("@照片", DBNull.Value));
}

else {
paras.Add(new SqlParameter("@照片",pictureBox1.ImageLocation));
}
}
else
{
MessageBox.Show("照片不能为空","提示");
}

 同时还应该将所选文件的路径保存下来

   

this.pictureBox1.Image = Image.FromFile(openFileDialog1.FileName);
pictureBox1.ImageLocation = @openFileDialog1.FileName;//注意要有@ 

结果:

 

转载于:https://www.cnblogs.com/2714585551summer/p/5280597.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,需要在JSP页面中使用form表单来上传文件,并且添加enctype属性来指定form表单的编码类型为multipart/form-data,示例如下: ``` <form action="upload.jsp" method="post" enctype="multipart/form-data"> <input type="file" name="file"> <input type="submit" value="上传"> </form> ``` 然后,在后台的upload.jsp页面中,需要使用Commons FileUpload组件来处理上传的文件,并将文件存储数据库中。可以按照以下步骤进行操作: 1. 创建DiskFileItemFactory对象,并设置缓冲区大小和临时文件存储路径: ``` DiskFileItemFactory factory = new DiskFileItemFactory(); factory.setSizeThreshold(4096); factory.setRepository(new File("D:/temp")); ``` 2. 创建ServletFileUpload对象,并设置文件上传的最大值和编码格式: ``` ServletFileUpload upload = new ServletFileUpload(factory); upload.setSizeMax(1024*1024*10); //设置文件上传的最大值为10M upload.setHeaderEncoding("UTF-8"); //设置编码格式为UTF-8 ``` 3. 解析请求,获取上传的文件: ``` List<FileItem> items = upload.parseRequest(request); for (FileItem item : items) { if (!item.isFormField()) { //判断是否为文件域 String filename = item.getName(); //获取文件名 InputStream in = item.getInputStream(); //获取文件输入流 //将文件存储数据库中 //... } } ``` 4. 将文件存储数据库中: ``` //获取数据库连接 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "root"); PreparedStatement pstmt = null; //插入数据的SQL语句 String sql = "INSERT INTO image (name, content) VALUES (?, ?)"; try { pstmt = conn.prepareStatement(sql); pstmt.setString(1, filename); pstmt.setBinaryStream(2, in, in.available()); pstmt.executeUpdate(); } catch (SQLException e) { e.printStackTrace(); } finally { //关闭数据库连接和输入流 if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (in != null) { try { in.close(); } catch (IOException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } ``` 以上就是使用Commons FileUpload组件将图片上传到数据库的基本步骤。需要注意的是,在实际应用中,还需要进行文件类型、大小、重名等的校验,以及异常处理等操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值