Global.asax(全局应用程序类)

本文介绍了一个使用C#实现的应用程序启动、关闭及会话管理的示例。通过SQL Server进行数据交互,记录应用启动时的总数,并在会话开始与结束时更新在线用户数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值