jsp 连接sql server的问题

王朝干货·作者佚名  2011-12-15
窄屏简体版  字體: |||超大  

1、java.lang.NullPointerException异常

一般是对一个NULL值的变量进行操作引起的。例如下面的操作就会抛出异常java.lang.NullPointerException。

<%

String a=null;

a.substring(0,1);

%>

为避免这种异常,最好在对变量操作之前检查看它是否是NULL值。例如:

<%

String name=Session.getAttribute("name");

if(name==null){

//执行某种操作

}

else{

//执行另种操作

}

%>

2、JSP是大小写敏感的

JSP程序是区分大小写的,在编写JSP程序时一定要注意不要将大小写混淆,例如:

String abook;与String Abook;它们代表两个不同的字符串变量。用过其他编程语言的人最容易犯这种错误。

3、未被初始化错误

先来看如下一段代码:

public String Compare(String user1,String user2){

boolean result;

if(user1.compareTo(user2)==0)

result=true;

return result;

}

乍一看这段程序并没有任何问题,但在编译的时候会出现如下错误提示:

variable result might not have been initialized

return result

^

这是因为,当if条件为false的时候,result可能会没有被赋予初值,而return的时候则会出错。java编译器很聪明的检查出了这一错误并

在编译的时候给予了提示。这需要程序员在声明result的时候或者在返回result之前给它赋值。所以在定义一个变量时最好赋予一个初值。

4、变量未定义错误

可能大家都知道变量在使用之前要定义,但是不经意间却常常犯这种错误,例如下面一段代码:

<html>

<body>

<table>

<%

for(int i=0;i<5;i++)

{

String s=""+i;

}

%>

<tr>

<td>i现在的值是:</td>

<td><%=s%></td>

</tr>

</table>

</body>

</html>

编译时会报错:

Undefined variable:s

out.print(s);

^

1 error

出现这种错误是由于逻辑错误,for循环的结束标记符号"}"放错了位置,正确的写法应该如下段代码所示:

<html>

<body>

<table>

<%

for(int i=0;i<5;i++)

{

String s=""+i;

%>

<tr>

<td>i现在的值是:</td>

<td><%=s%></td>

</tr>

<%}%>

</table>

</body>

</html>

5、SQL语句换行书写时未加适当的空格而导致的错误

我们先来看下面这段代码:

String name=tom;

String sql="select * from userTable"+

"where user_name='"+name+"'"+

"and user_age=22";

上面的代码在执行的时候将转换成这样的SQL语句:

select * from userTablewhere user_name='name'and user_age=22

从输出的SQL语句可以看出userTable 和 where 之间以及'name'和and之间都缺空格,这样是不能从数据库中取出数据的。正确的写法应该

如下所示:

String name=tom;

String sql="select * from userTable"+

" where user_name='"+name+"'"+

" and user_age=22";

org.apache.jasper.JasperException: Unable to compile class for JSP

确认这一行里面你的CLASS没有错误.

java.io.UTFDataFormatException: Invalid byte 1 of 1-byte UTF-8 sequence.

确认你的机器不是WINDOWS,如果是最好type="gb2312"

重新部署你的pro以及restart your toomcat.

小贴士:① 若网友所发内容与教科书相悖,请以教科书为准;② 若网友所发内容与科学常识、官方权威机构相悖,请以后者为准;③ 若网友所发内容不正确或者违背公序良俗,右下举报/纠错。
 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航