C# code
<script runat="server"> void Application_Start(object sender, EventArgs e) { // 在应用程序启动时运行的 System.Data.SqlClient.SqlConnection con = DBConnect.createConnection(); con.Open(); System.Data.SqlClient.SqlCommand com = new System.Data.SqlClient.SqlCommand( "select * from total", con); int count =System.Convert.ToInt32(com.ExecuteScalar()); con.Close(); Application["total"] = count; Application["online"] = 0; } void Application_End(object sender, EventArgs e) { // 在应用程序关闭时运行的代码 System.Data.SqlClient.SqlConnection con = DBConnect.createConnection(); con.Open(); System.Data.SqlClient.SqlCommand com = new System.Data.SqlClient.SqlCommand( "update total set num="+Application["total"].ToString(), con); com.ExecuteNonQuery(); con.Close(); } void Application_Error(object sender, EventArgs e) { // 在出现未处理的错误时运行的代码 } void Session_Start(object sender, EventArgs e) { // 在新会话启动时运行的代码 Session.Timeout = 1; Application.Lock(); Application["total"] = System.Convert.ToInt32(Application["total"]) + 1; Application["online"] = System.Convert.ToInt32(Application["online"]) + 1; Application.UnLock(); } void Session_End(object sender, EventArgs e) { // 在会话结束时运行的代码。 // 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为 // InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer // 或 SQLServer,则不会引发该事件。 Application.Lock(); Application["online"] = System.Convert.ToInt32(Application["online"]) - 1; Application.UnLock(); } </script>