过程 'sp_GetNoticeQuery' 需要参数 '@Employee',但未提供该参数。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.Data.SqlClient.SqlException: 过程 'sp_GetNoticeQuery' 需要参数 '@Employee',但未提供该参数。源错误:
行 341: cmd.CommandType=CommandType.StoredProcedure;
行 342: cn.Open();
行 343: SqlDataReader dr= cmd.ExecuteReader(CommandBehavior.CloseConnection);
行 344: return dr;
行 345: }
源文件: E:\vss\Source\ITMS\DataAccess\SqlTools.cs 行: 343 堆栈跟踪:
[SqlException (0x80131904): 过程 'sp_GetNoticeQuery' 需要参数 '@Employee',但未提供该参数。]
System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection) +862234
System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection) +739110
System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj) +188
System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj) +1956
System.Data.SqlClient.SqlDataReader.ConsumeMetaData() +31
System.Data.SqlClient.SqlDataReader.get_MetaData() +62
代码:
void Application_Error(object sender, EventArgs e)
{
// 在出现未处理的错误时运行的代码
Exception erroy = Server.GetLastError().GetBaseException();
string err = "";
if (System.Web.HttpContext.Current != null)
{
err = "出错页面是:" + System.Web.HttpContext.Current.Request.Url.ToString() + "<br>";
}
err += "异常信息:" + erroy.Message.ToString() + "<br>";
err += "源错误:" + erroy.Source + "<br>"; Application["erroy"] = err;
Application["erroyMessage"] = erroy.Message;
}怎么获得这个源错误部分!
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.Data.SqlClient.SqlException: 过程 'sp_GetNoticeQuery' 需要参数 '@Employee',但未提供该参数。源错误:
行 341: cmd.CommandType=CommandType.StoredProcedure;
行 342: cn.Open();
行 343: SqlDataReader dr= cmd.ExecuteReader(CommandBehavior.CloseConnection);
行 344: return dr;
行 345: }
源文件: E:\vss\Source\ITMS\DataAccess\SqlTools.cs 行: 343 堆栈跟踪:
[SqlException (0x80131904): 过程 'sp_GetNoticeQuery' 需要参数 '@Employee',但未提供该参数。]
System.Data.SqlClient.SqlConnection.OnError(SqlException exception, Boolean breakConnection) +862234
System.Data.SqlClient.SqlInternalConnection.OnError(SqlException exception, Boolean breakConnection) +739110
System.Data.SqlClient.TdsParser.ThrowExceptionAndWarning(TdsParserStateObject stateObj) +188
System.Data.SqlClient.TdsParser.Run(RunBehavior runBehavior, SqlCommand cmdHandler, SqlDataReader dataStream, BulkCopySimpleResultSet bulkCopyHandler, TdsParserStateObject stateObj) +1956
System.Data.SqlClient.SqlDataReader.ConsumeMetaData() +31
System.Data.SqlClient.SqlDataReader.get_MetaData() +62
代码:
void Application_Error(object sender, EventArgs e)
{
// 在出现未处理的错误时运行的代码
Exception erroy = Server.GetLastError().GetBaseException();
string err = "";
if (System.Web.HttpContext.Current != null)
{
err = "出错页面是:" + System.Web.HttpContext.Current.Request.Url.ToString() + "<br>";
}
err += "异常信息:" + erroy.Message.ToString() + "<br>";
err += "源错误:" + erroy.Source + "<br>"; Application["erroy"] = err;
Application["erroyMessage"] = erroy.Message;
}怎么获得这个源错误部分!
* Copyright (C)
* 版权所有。
*
* 文件名 :ErrorManager.cs
* 功能描述:asp.net中统一的错误修理,与本类相配套需要增加一个错误信息显示页面,如error.aspx
*
* 使用说明:1. 在Application_Start()中启动定时器(定时清空错误信息):ErrorManager.Instance.Start(),
* 默认12小时运行一次,或用ErrorManager.Instance.SetTimerInterval()设置。
* 2. 在Application_Error()中,当发生错误时,保存这个错误信息并转到error.aspx中显示这个错误
* string key = ErrorManager.Instance.AddError();
* Response.Redirect("error.aspx?key=" + key);
* 3. 在error.aspx中通过url传来的key,取得并显示错误信息:
* string err = ErrorManager.Instance.GetError(key)
* err中前19个字符是错误发生的时间,后面是错误信息。
* 4. 为了捕捉Session超时的错误,而不是返回Session[key]是null的错误信息,本类增加了GetSession()
* 和SetSession函数来统一管理Session,以后aspx中不能直接读取Session,而必须通过本类来读取。
*
*
* 创建标识:
*
* 修改标识:
* 修改描述:
*
* 修改标识:
* 修改描述:
*----------------------------------------------------------------*/
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Collections;/**//// <summary>
/// Summary description for Error
/// </summary>
public class ErrorManager
{
private System.Timers.Timer m_timer;
private Hashtable m_htErr; /**//// <summary>
/// 私有的构造函数
/// </summary>
private ErrorManager()
{
this.m_timer = new System.Timers.Timer();
this.m_timer.Enabled = false;
this.m_timer.Interval = 12 * 60 * 60 * 1000; //默认12个小时执行一次
this.m_timer.Elapsed += new System.Timers.ElapsedEventHandler(m_timer_Elapsed);
this.m_htErr = new Hashtable();
} /**//// <summary>
/// 单例模式的接口
/// </summary>
public static readonly ErrorManager Instance = new ErrorManager(); /**//// <summary>
/// 设置定时器的频率,单位是毫秒
/// </summary>
/// <param name="Interval">毫秒</param>
public void SetTimerInterval(int Interval)
{
this.m_timer.Interval = Interval;
} /**//// <summary>
/// 定时器开始
/// </summary>
public void TimerStart()
{
this.m_timer.Enabled = true;
} /**//// <summary>
/// 定时器结束
/// </summary>
public void TimerStop()
{
this.m_timer.Enabled = false;
} /**//// <summary>
/// 发生了一个错误,把错误信息保存起来,并返回错误的id,便于页面中读取
/// </summary>
/// <returns>返回错误的id</returns>
public string AddError()
{
string key = Guid.NewGuid().ToString();
string msg = System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")
+ HttpContext.Current.Server.GetLastError().GetBaseException().Message;
this.m_htErr.Add(key, msg); HttpContext.Current.Server.ClearError(); return key;
} /**//// <summary>
/// 返回指定Key的错误信息,前19个字符是错误发生的时间
/// </summary>
/// <param name="key">key,是一个guid</param>
/// <returns>返回错误信息</returns>
public string GetError(string key)
{
return this.m_htErr[key].ToString();
} /**//// <summary>
/// 定时在Hashtable中清理错误信息
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void m_timer_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
{
ArrayList list = new ArrayList();
lock (this.m_htErr)
{
DateTime now = DateTime.Now;
TimeSpan ts;
foreach (string key in this.m_htErr.Keys)
{
//前19个字符是错误发生的日期,yyyy-MM-dd HH:mm:ss
string time = this.m_htErr[key].ToString().Substring(0, 19);
ts = now - Convert.ToDateTime(time);
if (ts.TotalMinutes > 20) //把20分钟前的错误信息从hashtable中清除
list.Add(key);
} foreach (string key in list)
{
this.m_htErr.Remove(key);
}
} }
Session操作的封装#region Session操作的封装
/**//// <summary>
/// 取得指定键值的Session
/// </summary>
/// <param name="key">键值</param>
/// <returns>键内容值</returns>
public object GetSession(string key)
{
object val = HttpContext.Current.Session[key];
if (val == null)
throw new Exception("页面超时,请重新登录。"); return val;
} /**//// <summary>
/// 设置Session
/// </summary>
/// <param name="key">键值</param>
/// <param name="val">键内容</param>
public void SetSession(string key, object val)
{
HttpContext.Current.Session[key] = val;
}
#endregion
}