错误:java.lang.NullPointerException 在javax.swing.ImageIcon。(未知来源) 在Show $ 2.actionPerformed(Show.java:79)
我认为问题出现在BufferedImage
中,是否还有其他选项来检索图像(Blob)表单数据库。我正在使用Sqlite数据库。
这就是守则:
public class Show extends JFrame {
private JPanel contentPane;
private JTextField id;
BufferedImage bufImg = null;
JLabel img=null;
InputStream in=null;
ImageIcon imgs=null;
/**
* Launch the application.
*/
public static void main(String[] args) {
EventQueue.invokeLater(new Runnable() {
public void run() {
try {
Show frame = new Show();
frame.setVisible(true);
} catch (Exception e) {
e.printStackTrace();
}
}
});
}
/**
* Create the frame.
*/
Connection con=null;
public Show() {
con=dB.Connect();
setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
setBounds(100, 100, 588, 432);
contentPane = new JPanel();
contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
setContentPane(contentPane);
contentPane.setLayout(null);
id = new JTextField();
id.setBounds(158, 23, 86, 20);
contentPane.add(id);
id.setColumns(10);
JButton show = new JButton("New button");
show.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
try{
//String iid=null;
//iid="10";
//iid=id.getText().toString();
String q="select image from image where id='"+id.getText()+"'";
PreparedStatement ps=con.prepareStatement(q);
//ps.setString(1, id.getText().trim());
//ps.executeQuery();
ResultSet rs=ps.executeQuery();
while (rs.next()) {
in= rs.getBinaryStream("image");
bufImg = ImageIO.read(in);
img.setIcon(new ImageIcon(bufImg));// Console shows the error is in this line
}
rs.close();
ps.close();
}catch(Exception c)
{
c.printStackTrace();
}
}
});
show.setBounds(302, 22, 89, 23);
contentPane.add(show);
img = new JLabel("");
img.setBounds(151, 99, 325, 284);
contentPane.add(img);
}
}
答案 0 :(得分:1)
似乎无法识别图像的数据格式(This is the only time ImageIO returns null)。但是,由于图像是supported format(PNG),这是一个非常奇怪的事件。我能够在Oracle错误跟踪器上找到PNG loading bug,但该漏洞在2006年被标记为已解决。
我最好的建议是尝试使用第三方图片库,例如Commons Imaging,Sixlegs或其他许多图片库。