网络编程
位置:首页>> 网络编程>> 数据库>> Java+mysql本地图片上传数据库及下载示例

Java+mysql本地图片上传数据库及下载示例

作者:Ro_kin  发布时间:2023-07-23 19:49:13 

标签:java,上传文件

做一个将本地图片上传到mysql数据库的小实例,顺便也下载下来到桌面检测是否上传成功。

在写代码之前得先在数据库中建立image表,用来存储图片。


create table image
(id int primary key auto_increment ,
name varchar(30) COMMENT '名称',
content mediumblob COMMENT '图片');

下面直接上代码:


package jdbc_imagetest;

import java.io.*;
import java.sql.*;
/**
* 将本地文件的图片传到数据库的test的image表中并下载到本机桌面
*/
public class Test1 {

private static String url="jdbc:mysql://localhost:3306/test";
 private static String user="root";
 private static String password="123456";
 private static Connection con;

public static void main(String[] args) throws Exception {
   Class.forName("com.mysql.jdbc.Driver");
   con=DriverManager.getConnection(url,user,password);
   shangchuan();
   xiazai();    
 }
 //添加图片到数据库test4的file表
 public static void shangchuan() throws Exception{
   String sql="insert into image(name,content) values(?,?)";
   PreparedStatement ptmt=con.prepareStatement(sql);
   ptmt.setString(1, "美女.jpg");
   InputStream is=null;
   is=new FileInputStream("D:\\Pictures\\3.jpg");
   ptmt.setBinaryStream(2, is,is.available());
   //方法说明:PreparedStatement.setBinaryStream(int parameterIndex, InputStream x, int length)
   ptmt.execute();
   System.out.println("图片添加成功!");

}
 //从数据库中把图片下载至桌面
 public static void xiazai() throws Exception{
   String sql="select content from image where id=3";//在我这里3.jpg是第三张图片
   Statement stmt=con.createStatement();
   ResultSet rs=stmt.executeQuery(sql);//将查询结果给rs
   if(rs.next()){
     InputStream is=rs.getBinaryStream("fcontent");
     //.getBinaryStream():a Java input stream that delivers the database column value as a stream of uninterpreted bytes
     FileOutputStream fos=new FileOutputStream("C:\\Users\\Desktop\\美女.jpg");
     byte[] buffer=new byte[1024];
     int len=0;
     while((len=is.read(buffer))!=-1){
       fos.write(buffer,0,len);//将数据库的图片写出
     }
     System.out.println("下载成功!已下载至桌面,请查看");
   }else{
     System.out.println("图片不存在!");
   }
   con.close();
 }

}

测试成功

来源:http://blog.csdn.net/ro_kin/article/details/54705782

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com