鱼C论坛

 找回密码
 立即注册
查看: 455|回复: 3

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

[复制链接]
发表于 2024-1-3 21:29:04 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
调取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();
                }
               
        }
       

       
}
       
最佳答案
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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2024-1-3 21:36:21 | 显示全部楼层
FishC 发表于 2024-1-3 21:29
在您的代码中,是没有将图片保存到工程文件夹中的。

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

谢谢小助理 事实上图片保存在里工程文件夹里 但是在eclipse project explorer上无法显示 要怎样设置才能让让它显示出来呢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 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 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-21 20:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表