当前位置: 代码迷 >> Java Web开发 >> java.lang.NullPointerException 出现这中错误
  详细解决方案

java.lang.NullPointerException 出现这中错误

热度:844   发布时间:2006-07-28 21:17:27.0
java.lang.NullPointerException 出现这中错误

这是连接数据库
package upload;
import java.sql.*;
import java.io.*;
public class connect{
String driver="com.mysql.jdbc.Driver";
String url="jdbc:mysql://localhost:3306/upload";
Connection con=null; //声明一个共享的连接对象
Statement stat=null;
ResultSet rs=null;
int rowCount=0; //总的记录数
public connect(){
try{
Class.forName(driver);
con=DriverManager.getConnection(url,"root","java");
System.out.print("连接成功");
}catch(Exception e){e.printStackTrace();
}
}

//取得数据库连接
public Connection getConn(){
return con;
}

//执行sql语句
public ResultSet myQuery(String sql) throws SQLException{
stat=con.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
//结果集的游标可上下移动,可更新数据库中的表
rs=stat.executeQuery(sql);//返回结果集.
return rs;
}
//关闭数据库连接
public void myClose() throws SQLException{
con.close();
}



}





这是插入数据

package upload;

import javax.servlet.*;
import javax.servlet.http.*;
import java.util.*;
import java.io.*;
import java.text.*;
import java.sql.*;

import com.oreilly.servlet.*;
import com.oreilly.servlet.multipart.*;
public class upload extends HttpServlet{
private static final String CONTENT_TYPE="text/html; charset=GBK";
Connection conn;
int maxPostSize=3*5*1024*1024;
public void doPost(HttpServletRequest request,HttpServletResponse response) throws ServletException ,IOException{
String name=request.getParameter("name");
response.setContentType(CONTENT_TYPE);
String dirs=request.getRealPath("/");
String saveDirectory=dirs+"photo";
PrintWriter out=response.getWriter();
connect connectdata=new connect();
conn=connectdata.getConn();
MultipartRequest multi=new MultipartRequest(request,saveDirectory,maxPostSize,"GBK");
Enumeration files=multi.getFileNames(); //处理文件的上传
while(files.hasMoreElements()){
String names=(String)files.nextElement();
File f=multi.getFile(names);
if(f!=null){
String filename=multi.getFilesystemName(names);
String lastFilename=saveDirectory+"\\"+filename;
String sql="insert into java3(name,filename) values('"+name+"','"+filename+"')";
try{
Statement stmt=conn.createStatement();
stmt.execute(sql);
out.print("<script> alert('成功添加新成员!'); this.location.href='show.jsp'</script>");
}catch(Exception ex){
ex.printStackTrace();
}
}
}
}
public void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req,resp);
}
}




这是上传图片并在当前页显示
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*" errorPage="" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head>

<body>
<form id="form1" name="form1" enctype="multipart/form-data" method="post" action="/show/upload">
<table><tr><td>
<p>图片名称:
<label>
<input type="text" name="name" />
</label>
</p>
<p>
<input type="file" name="file"/>
</p></td></tr>
<tr><td><input type="submit" name="submit" value="确定"/></td></tr>
</table>
<%
Statement stmt;
ResultSet rs=null;
Connection conn;
try{
String sql="select * from zhang order by id desc";
Class.forName("com.mysql.jdbc.Driver");
conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/upload","root","java");
stmt=conn.createStatement(java.sql.ResultSet.TYPE_SCROLL_INSENSITIVE,java.sql.ResultSet.CONCUR_READ_ONLY);
stmt.executeQuery(sql);

while(rs.next()){
String file=rs.getString("filename");
String name=rs.getString("name");
%>
<table border="0" cellpadding="0" cellspacing="0" height="150" width="150">
<tr><td><%=name%></td></tr>
<tr>
<td width="196" rowspan="5">
<div align="center"><A
href="photo/<%=file%>" target=_blank><img src="photo/<%=file%>" width="100" height="100" hspace="0" vspace="0" border="0" /></A></div></td>
</tr>
</table>
<%}
}catch(Exception e){out.print(e);}
%>
</form>
</body>
</html>


结果不出现显示 而且数据存不进去数据库中 但在临时目录photo中存有图片
出现 java.lang.NullPointerException 错误

这是我建的表
create database upload;
use upload;
create table zhang(id int(30) not null auto_increment,name varchar(20) not null,filename varchar(50) not null,primary key (id));


我都改了半天了 还是改不成功
到底是哪错了 请各位 师哥师姐们帮我看看
谢谢!

搜索更多相关主题的帖子: java  lang  

----------------解决方案--------------------------------------------------------
能把错误栈完整的发上来给我们 欣赏 一下么?

----------------解决方案--------------------------------------------------------

错误是一个页面 除了一个文本框 ,一个 上传文件的文本域 就是“java.lang.NullPointerException” 这句话了
而且我提交 页面空白

我想是插入数据那个java类错误 因为当我点提交时 ,没出现“添加新成员成功”这个对话框

可是不知道错在哪


----------------解决方案--------------------------------------------------------
哎呀,错误信息不够多,我判断不来了
----------------解决方案--------------------------------------------------------

谁帮我 看看呗 我实在弄不出来啊
到底错哪了呢


----------------解决方案--------------------------------------------------------
神说的对,你应该把错误信息详细的列出来
----------------解决方案--------------------------------------------------------
最简单的办法就是在插入数据库前System.out.println();打印你前边提取出来的信息,然后在测试是不是数据库连上了,在测试连上之后的打印查询或者是插入结果语句。
----------------解决方案--------------------------------------------------------

再说了,你的这个上传例子真的太复杂了,现在给你说个简单的,综合运用jspsmart.jar或者你用struts 里边自己带的那个包来上传很简单的。

%>


----------------解决方案--------------------------------------------------------

我也出现这样的问题,不过在网上找到以下解决方案,不知道是否正确
java.lang.NullPointerException

使用基本的JAVA数据类型,变量的值要么已经是默认值,如果没有对其正常赋值,程序便不能通过编译,因此使用基本的JAVA数据类型(double,float,boolean,char,int,long)一般不会引起空指针异常。由此可见,空指针异常主要跟与对象的操作相关。

下面先列出了可能发生空指针异常的几种情况及相应解决方案:

不管对象是否为空就直接开始使用。

(JSP)代码段1:

out.println(request.getParameter("username"));

描述:

代码段1的功能十分简单,就是输出用户输入的表域"username"的值。

说明:

看上去,上面的语句找不出什么语法错误,而且在大多数情况下也遇不到什么问题。但是,如果某个用户在输入数据时并没有提供表单域"username"的值,或通过某种途径绕过表单直接输入时,此时request.getParameter("username")的值为空(不是空字符串,是空对象null。),out对象的println方法是无法直接对空对象操作,因此代码段1所在的JSP页面将会抛出"java.lang.NullPointerException"异常。

即使对象可能为空时,也调用java.lang.Object或Object对象本身的一些方法如toString(), equals(Object obj)等操作。

(JSP)代码段2:

String userName = request.getParameter("username");

If (userName.equals("root"))

{....}

描述:

代码段2的功能是检测用户提供的用户名,如果是用户名称为"root"的用户时,就执行一些特别的操作。

说明:

在代码段2中,如果有用户没有提供表单域"username"的值时,字符串对象userName为null值,不能够将一个null的对象与另一个对象直接比较,同样,代码段2所在的JSP页面就会抛出(java.lang.NullPointerException)空指针错误。

(JSP)代码段3:

String userName = session.getAttribute("session.username").toString();

描述:

代码段3的功能是将session中session.username的值取出,并将该值赋给字符串对象 userName。

说明:

在一般情况下,如果在用户已经进行某个会话,则不会出现什么问题;但是,如果此时应用服务器重新启动,而用户还没有重新登录,(也可能是用户关闭浏览器,但是仍打开原来的页面。)那么,此时该session的值就会失效,同时导致session中的session.username的值为空。对一个为null的对象的直接执行toString()操作,就会导致系统抛出(java.lang.NullPointerException)空指针异常。

解决方案:

为了确保进行操作或引用的对象非空,假若我们要对某对象进行操作或引用,我们首先去检查该对象是否已经实例化且不为空;并且在系统中加入针对对象为空时情况的处理。

如:采用String对象保存用户提交的结果;在如果涉及对象的操作时,先检测其是否为空后,检查到对象为空后,可再选择进行以下任一种处理方式:

处理方式 1) 检查到对象为空时,设置对象值为空字符串或一个默认值;

处理方式 2) 检测到对象为空时,根本不执行某操作,直接跳转到其他处理中。

处理方式 3) 检查到对象为空时,提示用户操作有错误。

将代码段2按以上方式进行改写,得到:

方式1:

String userName = request.getParameter("username");

// 该变量值为空时,转化为默认空字符串

If (userName == null)

userName = "";

If (userName.equals("root"))

{..........}

方式2:

String userName = request.getParameter("username");

// 该变量值为空时,转化为默认空字符串,不执行有关操作。

If (usreName != null)

{

If (userName.equals("root"))

{..........}

}

方式3:

String userName = request.getParameter("username");

// 该变量值为空时,转化为默认空字符串,不执行有关操作。

If (usreName == null)

{

// 提示用户输入信息为空

}

实际中,上面提供到三种处理方式也同样适用于其他异常的处理:

异常处理方式 1) 检查到异常出现,设置对象值为空字符串或一个默认值;

异常处理方式 2) 检测到异常出现,根本不执行某操作,直接跳转到其他处理中。

异常处理方式 3) 检查到异常出现,提示用户操作有错误。


----------------解决方案--------------------------------------------------------
  相关解决方案