前言


       状态管理是在同一页或不同页的多个请求发生时,维护状态和页信息的过程。因为Web应用程序的通信协议使用了无状态的HTTP协议,所以当客户端请求页面时,ASP.NET服务器端都会重新生成一个网页实例。此时,旧网页的任务完成,旧网页的实例也随之消失。这种无状态,意味着客户端用户在浏览器中的一些状态或是对数据的一些修改都将丢失。
        为了弥补这种基于web应用程序的固有限制,ASP.NET提供了多种用于管理状态的功能。

简单聊天室


这里运用System.Web命名空间的那些管理状态的类,做一个简单的聊天室
0.效果图
 
【 不知道为什么下拉框DropDownList1的选中项老是获取不了,有谁知道的还请告诉我一声啊,哈哈哈】

1.Default.aspx页面:用于用户登录,一个用户文本框,一个登录按钮,给登录按钮添加事件
后台主要代码
  1. protected void Button1_Click(object sender, EventArgs e)
  2. {
  3. Application.Lock();
  4. int intUserNum;
  5. string user;
  6. string[] users;
  7. string strUserName;
  8. intUserNum = Convert.ToInt32(Application["userNum"]);
  9. if (intUserNum > 20)
  10. {
  11. Response.Write("在线人数超过20人,不能登录了!");
  12. Response.Redirect("Default.aspx");
  13. }
  14. else {
  15. user = Application["user"].ToString();
  16. users = user.Split(',');
  17. strUserName = TextBox1.Text.Trim();
  18. for (int i = 0; i < intUserNum; i++) {
  19. if (users[i] == strUserName)
  20. {
  21. Response.Redirect("Default.aspx?value=1");
  22. }
  23. }
  24. if (users == null)
  25. Application["user"] = strUserName;
  26. else
  27. Application["user"] += "," + strUserName;
  28. intUserNum += 1;
  29. Application["userNum"] = intUserNum.ToString();
  30. Session["user"] = strUserName;
  31. Application.UnLock();
  32. Response.Redirect("main.aspx"); ;
  33. }
  34. }
2.Left.aspx页面:主要用于呈现在线人数和在线人员名单,由2个label和1个textbox组成
后台主要代码
  1. public partial class Left : System.Web.UI.Page
  2. {
  3. private ArrayList ItemList = new ArrayList();
  4. protected void Page_Load(object sender, EventArgs e)
  5. {
  6. Application.Lock();
  7. if (Session["user"] == null)
  8. Response.Redirect("Default.aspx");
  9. else
  10. Label1.Text = Session["user"].ToString();
  11. int userCount = int.Parse(Application["userNum"].ToString());
  12. Label2.Text = userCount.ToString();
  13. string user = Application["user"].ToString();
  14. string[] users = user.Split(',');
  15. for (int i = (userCount-1); i >= 0; i--) {
  16. ItemList.Add(users[i]);
  17. }
  18. ListBox1.DataSource = ItemList;
  19. ListBox1.DataBind();
  20. Application.UnLock();
  21. }
  22. }
3.Right.aspx页面:用于呈现聊天记录,由一个textbox组成
后台主要代码
  1. protected void Page_Load(object sender, EventArgs e)
  2. {
  3. Application.Lock();
  4. if (!IsPostBack) {
  5. string chat=Application["chats"].ToString();
  6. int chatNum=int.Parse(Application["current"].ToString()) ;
  7. string[] chats = chat.Split(',');
  8. for (int i = chatNum - 1; i >= 0; i--)
  9. {
  10. if(chatNum==0)
  11. TextBox1.Text=chats[i];
  12. else
  13. TextBox1.Text=TextBox1.Text+"\n"+chats[i];
  14. }
  15. }
  16. Application.UnLock();
  17. }
4.bottom.aspx页面:用于用户向其他用户发送消息,由一个下拉列表,文本框和发送按钮组成,按钮要添加事件
后台主要代码
  1. public partial class bottom : System.Web.UI.Page
  2. {
  3. protected void Page_Load(object sender, EventArgs e)
  4. {
  5. Application.Lock();
  6. string userName = Application["user"].ToString();
  7. string[] users = userName.Split(',');
  8. DropDownList1.DataSource = users;
  9. DropDownList1.DataBind();
  10. Application.UnLock();
  11. }
  12. protected void Button1_Click(object sender, EventArgs e)
  13. {
  14. Application.Lock();
  15. int current = int.Parse(Application["current"].ToString());
  16. string liaotian = Session["user"] + "对" + DropDownList1.SelectedValue.ToString() + "说:" + TextBox1.Text.Trim() + DateTime.Now.ToString();
  17. if (current == 0 || current > 40)
  18. {
  19. current = 0;
  20. Application["chats"] = liaotian;
  21. }else{
  22. Application["chats"] +=","+ liaotian;
  23. }
  24. current += 1;
  25. Application["current"] = (object)current;
  26. Application.UnLock();
  27. }
  28. }
5.main.aspx页面:用于组合前面3个页面,使用iframe
主要代码
  1. <div>
  2. <iframe id="ifraLeft" name="ifraLeft" src="Left.aspx"
  3. style="width:200px;height:500px;float:left;margin-left:10px;margin-top:10px;background-color:grey;border:2px solid #000000"></iframe>
  4. <iframe id="ifraRight" name="ifraRight" src="Right.aspx"
  5. style="width:700px;height:500px;float:left;margin-top:10px;background-color:#000000;border:2px solid #000000;"></iframe>
  6. <iframe id="ifrabottom" name="ifrabottom" src="bottom.aspx"
  7. style="width:900px;height:50px;margin-left:10px;margin-top:10px;background-color:red;border:2px solid #000000;"></iframe>
  8. </div>

案例代码下载

C#实例之简单聊天室(状态管理)的更多相关文章

  1. java web利用mvc结构实现简单聊天室功能

    简单聊天室采用各种内部对象不适用数据库实现. 一个聊天室要实现的基本功能是:         1.用户登录进入聊天室, 2.用户发言 3.用户可以看见别人发言 刚才算是简单的需求分析了,现在就应该是进 ...

  2. 基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍。最后我们将会实现一个基于Server-Sent Event和Flask简单的在线聊天室。

    基于Server-Sent Event的简单聊天室 Web 2.0时代,即时通信已经成为必不可少的网站功能,那实现Web即时通信的机制有哪些呢?在这门项目课中我们将一一介绍.最后我们将会实现一个基于S ...

  3. Python Socket 简单聊天室2

    上篇文章写了一个简单的单线程的一问一答的简单聊天室.这次我们使用SocketServer模块搭建一个多线程异步的聊天室. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 ...

  4. Asp.Net SignalR - 简单聊天室实现

    简单聊天室 使用持久链接类我们就可以做一些即时通讯的应用了,我使用Group做了一个简单的聊天室,先上图技术细节下面再讲 可以加入聊天室.创建聊天室.发送消息,下面就说说我是如何通过Group做出来的 ...

  5. SpringBoot 搭建简单聊天室

    SpringBoot 搭建简单聊天室(queue 点对点) 1.引用 SpringBoot 搭建 WebSocket 链接 https://www.cnblogs.com/yi1036943655/p ...

  6. ASP.NET SingalR + MongoDB 实现简单聊天室(一):搭建基本框架

    ASP.NET SingalR不多介绍.让我介绍不如看官网,我这里就是直接上源代码,当然代码还是写的比较简单的,考虑的也少,希望各位技友多多提意见. 先简单介绍聊天室功能: 用户加入聊天室,自动给用户 ...

  7. 利用socket.io+nodejs打造简单聊天室

    代码地址如下:http://www.demodashi.com/demo/11579.html 界面展示: 首先展示demo的结果界面,只是简单消息的发送和接收,包括发送文字和发送图片. ws说明: ...

  8. C++ socket 网络编程 简单聊天室

    操作系统里的进程通讯方式有6种:(有名/匿名)管道.信号.消息队列.信号量.内存(最快).套接字(最常用),这里我们来介绍用socket来实现进程通讯. 1.简单实现一个单向发送与接收 这是套接字的工 ...

  9. C#基于Socket的简单聊天室实践

    序:实现一个基于Socket的简易的聊天室,实现的思路如下: 程序的结构:多个客户端+一个服务端,客户端都是向服务端发送消息,然后服务端转发给所有的客户端,这样形成一个简单的聊天室功能. 实现的细节: ...

随机推荐

  1. nmcli几个常用命令

    1.nmcli connection 用于查看连接 2.nmcli device用于查看当前网络设备 3.nmcli connection modify用于修改当前连接配置 4.nmcli conne ...

  2. centos7 安装 iRedmail 后 给nginx添加虚拟主机

    iRedmail安装参考官方文档和 https://ywnz.com/linuxyffq/4563.html 准备工作 更新操作系统 yum update -y 安装必要组件 yum install ...

  3. 《C# GDI+ 破境之道》:第一境 GDI+基础 —— 第三节:画圆形

    有了上一节画矩形的基础,画圆形就不要太轻松+EZ:)所以,本节在画边线及填充上,就不做过多的讲解了,关注一下画“随机椭圆”.“正圆”.“路径填充”的具体实现就好.与画矩形相比较,画椭圆与之完全一致,没 ...

  4. Hapi+MySql项目实战配置插件-加载文件渲染母版(三)

    加载插件 一般在其它node框架下,我们安装好插件直接require('插件')就能正常使用了,但是在Hapi下我们必须要Server.register()方法,才能正常使用插件.举个例子: serv ...

  5. nethogs-linux程序网络使用情况

    netthogs可以显示每个程序的网络传输情况安装nethogs工具yum install https://mirrors.tuna.tsinghua.edu.cn/epel/7/x86_64/Pac ...

  6. Mysql 字符问题

    先看一下mysql支持的字符范围 *数值类型:1.整形: 类型                               大小     范围                              ...

  7. JS循环解决任意日期间的间隔天数

    用JS循环解决任意日期间的间隔天数,并求截止日期是周几 y1=1900 m1=1 d1=1 y2=2000 m2=5 d2=3 days=0 ydays=0 mdays=0 ddays=d2-d1 f ...

  8. RabbitMQ配置死信队列

    死信队列 消息传输过程中难免会产生一些无法及时处理的消息,这些暂时无法处理的消息有时候也是需要被保留下来的,于是这些无法被及时处理的消息就变成了死信. 既然需要保留这些死信,那么就需要一个容器来存储它 ...

  9. OpenCV4系列之图像梯度和边缘检测

    在图像处理中,求解图像梯度是常用操作. Sobel算子 Calculates the first, second, third, or mixed image derivatives using an ...

  10. 进阶之路 | 奇妙的IPC之旅

    前言 本文已经收录到我的Github个人博客,欢迎大佬们光临寒舍: 我的GIthub博客 学习清单: IPC的基础概念 多进程和多线程的概念 Android中的序列化机制和Binder Android ...