分类:
2008-10-15 16:39:22
原因:
(1)在提交数据的页面或webconfig中没有对validateRequest的属性进行正确的设置
(2)HTML里面写了两个 引起
解决:
方案一: 在.aspx文件头中加入这句: <%@ Page validateRequest="false" %>
方案二: 修改web.config文件:
2.“在没有任何数据时进行无效的读取尝试”解决办法
原因:
所返回的sqldatareader无数据记录,但没有作记录判断力处理。返回的是空值
加上判断即可: if (reader.read()) { TextName.Text =
reader["FieldName"].ToString(); }
3.数据为空。不能对空值调用此方法或属性。
原因:
若对象是null,那么调用对象的方法例如ToString()肯定出错一般是数据库字段的值为空
在grideview等数据控件常出现
解决:因此建议作NULL处理
4.阅读器关闭时 FieldCount 的尝试无效
原因:
使用了SqlDataReader来绑定数据后,将connection对象作了Close()处理
类似
public SqlDataReader GetSomething() { conn.open(); SqlDataReader reader = sqlcmd.ExcecutReader(CommandBehavior.CloseConnection)); conn.close();// occur error here return reader; } |
ader这样conn就可以自动关闭。
如果是使用的是SqlDataAdapter和DataSet那么请去掉显式关闭conn的调用。或者在finally
中调用之。
5.未能映射路径
原因:可能是在webconfig中的路径配置不正确所致
|
原因:
一般是在异常处理理或返回值时使用了 throw 或return ,可能是其位置放在前面,造成后面的代码执行到了。
解决:
把相关的异常抛出处理的语句(throw)或return 的语句放到代理执行的最后一行。
[1]