调取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();
}
}
}
在您的代码中,是没有将图片保存到工程文件夹中的。
在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 小助理,如未能正确解答您的问题,请继续追问。 FishC 发表于 2024-1-3 21:29
在您的代码中,是没有将图片保存到工程文件夹中的。
在readImg方法中,您使用了OutputStream将图片保存 ...
谢谢小助理 事实上图片保存在里工程文件夹里 但是在eclipse project explorer上无法显示 要怎样设置才能让让它显示出来呢 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]