mumei2018 发表于 2024-1-3 21:29:04

调取sql里保存的图片 运行后没报错 但是读取的图片并没有出现在工程里 请问什问题

调取sql里保存的图片 运行后没有报错 但是读取的图片并没有出现在工程文件夹里 请问是什问题


package mybatisTry3.mts_soft.test;


import java.sql.*;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;

public class Test3 {
        public static void main(String[] args) throws IOException {
                try {
                        Class.forName("com.mysql.cj.jdbc.Driver");
                        String url = "jdbc:mysql:///mybatis2";
                        String user = "root";
                        String pwd = "root";
                               
                        Connection conn = DriverManager.getConnection(url, user, pwd);
                        Test3 test = new Test3();
                        //test.saveImg(conn);
                        test.readImg(conn);
                       
                       

                       
                       
                       
                } catch (ClassNotFoundException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                } catch (SQLException e) {
                       //TODO Auto-generated catch block
                        e.printStackTrace();
                }
        }
       

       
        public void readImg(Connection conn) throws IOException {
                String sql= "select * from Student where id = 5";
               
                try {
                        PreparedStatement pstmt = conn.prepareStatement(sql);
                        ResultSet rs = pstmt.executeQuery();
                       
                        if(rs.next()) {
                                int id = rs.getInt(1);
                                String name = rs.getString(2);
                                Blob blob = rs.getBlob(6);
                               
                                InputStream is = blob.getBinaryStream();
                                OutputStream os = new FileOutputStream("amanda1.png");
                                int temp = 0;
                                while((temp = is.read())!=-1) {
                                        os.write(temp);
                                }
                                os.close();
                                is.close();
                                pstmt.close();
                                conn.close();
                        }
                       
                       
                } catch (SQLException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }
               
        }
       

       
}
       

FishC 发表于 2024-1-3 21:29:20

在您的代码中,是没有将图片保存到工程文件夹中的。

在readImg方法中,您使用了OutputStream将图片保存到本地磁盘。默认情况下,文件会保存在Java程序的当前工作目录。但由于您没有指定具体的路径,所以文件保存在了当前工作目录,并且文件名为"amanda1.png"。

当前工作目录可以通过System.getProperty("user.dir")获取,您可以在控制台输出一下看看,默认是在哪个目录。

如果您希望将图片保存到工程文件夹中,可以使用相对路径或者绝对路径来指定保存的位置。

比如,想要将图片保存到工程根目录下的一个名为"images"的文件夹中,可以这样修改:

String savePath = System.getProperty("user.dir") + "/images/amanda1.png";
OutputStream os = new FileOutputStream(savePath);

这样,图片就会保存在工程根目录下的"images"文件夹中了。

另外,记得在使用完数据库连接后,及时关闭连接,可以使用try-with-resources语句自动关闭连接,避免资源泄露:

try (Connection conn = DriverManager.getConnection(url, user, pwd);
   PreparedStatement pstmt = conn.prepareStatement(sql);
   ResultSet rs = pstmt.executeQuery()) {
    // 读取图片并保存
} catch (SQLException e) {
    e.printStackTrace();
}

希望能帮到您!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。

mumei2018 发表于 2024-1-3 21:36:21

FishC 发表于 2024-1-3 21:29
在您的代码中,是没有将图片保存到工程文件夹中的。

在readImg方法中,您使用了OutputStream将图片保存 ...

谢谢小助理 事实上图片保存在里工程文件夹里 但是在eclipse project explorer上无法显示 要怎样设置才能让让它显示出来呢

FishC 发表于 2024-1-3 21:36:31

mumei2018 发表于 2024-01-03 21:36
谢谢小助理 事实上图片保存在里工程文件夹里 但是在ec ...

如果您已经将图片保存在工程文件夹中,但无法在Eclipse的Project Explorer上显示出来,可能是因为Eclipse没有自动刷新工程文件夹。您可以尝试手动刷新工程,或者在Eclipse的设置中开启自动刷新功能。

手动刷新工程:在Project Explorer上右键单击工程名,选择"Refresh"(或"刷新")选项,Eclipse将会重新加载并显示工程文件夹中的内容。

开启自动刷新功能:在Eclipse菜单栏中选择"Window"(或"窗口"),然后选择"Preferences"(或"首选项")。在弹出的对话框中,展开"General"(或"常规")选项,在下面找到"Workspace"(或"工作空间")选项。勾选"Refresh using native hooks or polling"(或类似的选项),然后点击"OK"。这样设置后,Eclipse将会自动监测工程文件夹的变化,并刷新显示。

请注意,如果您在运行时动态保存了图片到工程文件夹,可能需要手动刷新或等待一段时间后才能在Eclipse上看到更新的图片。

希望能帮助到您!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
页: [1]
查看完整版本: 调取sql里保存的图片 运行后没报错 但是读取的图片并没有出现在工程里 请问什问题