首页 / 软件开发 / C# / VS2005(c#)项目调试问题解决方案集锦
VS2005(c#)项目调试问题解决方案集锦2008-04-271.检测到有潜在危险的 Request.Form 值原因:(1)在提交数据的页面或webconfig中没有对validateRequest的属性进行正确的设置(2)HTML里面写了两个<form>引起解决:方案一: 在.aspx文件头中加入这句:方案二: 修改web.config文件: 以下是引用片段:
<configuration>
<system.web>
<pages validateRequest="false" />
</system.web>
</configuration>
因为validateRequest默认值为true。只要设为false即可。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;
}
在绑定的时候调用了这个方法来指定数据源。如果使用这个方法则需要在调用函数中关闭Reader这样conn就可以自动关闭。如果是使用的是SqlDataAdapter和DataSet那么请去掉显式关闭conn的调用。或者在finally中调用之。