Java swing,使用Eclipse从数据库检索映像时出错

时间:2015-07-31 17:14:22

标签: java database swing sqlite nullpointerexception

  

错误: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);
}

}

1 个答案:

答案 0 :(得分:1)

似乎无法识别图像的数据格式(This is the only time ImageIO returns null)。但是,由于图像是supported format(PNG),这是一个非常奇怪的事件。我能够在Oracle错误跟踪器上找到PNG loading bug,但该漏洞在2006年被标记为已解决。

我最好的建议是尝试使用第三方图片库,例如Commons ImagingSixlegs或其他许多图片库。