.NET C# Blazor 实现一个在线人数的功能

最终效果

在这里插入图片描述

画页面

OnlineUserCount.razor

<p style="margin-bottom:0"
   @onclick="()=>{
    IsShowOnlineUserList = !IsShowOnlineUserList;
}">
    <span style="color:red;">@OnlineCount</span>人正在浏览这篇文章
</p>
@{
    if (IsShowOnlineUserList)
    {
        <p style="margin-top: 1rem;">IP列表:</p>

        @foreach (var item in GetOnlineUserList())
        {
            <p style="margin-left: 2rem;">@item</p>
        }

    }
}

OnlineUserCount.razor.cs

using BootstrapBlazorApp.Shared.Common;

using Microsoft.AspNetCore.Components;
using Microsoft.AspNetCore.Http;

namespace BootstrapBlazorApp.Shared.Shared;

public partial class OnlineUserCount : ComponentBase, IAsyncDisposable
{	
    [Parameter]
    public string Uuid { get; set; }

    public bool IsShowOnlineUserList { get; set; } = false;

    /// <summary>
    /// 在线人数
    /// </summary>
    public int OnlineCount { get; set; }

    private string _ip { get; set; }

    private System.Threading.Timer _timer { get; set; }

    [Inject]
    private CacheCommon _cacheCommon { get; set; }

    [Inject]
    private IHttpContextAccessor _httpContextAccessor { get; set; }

	// 获取缓存中的数据
    public List<string> GetOnlineUserList()
    {
    	// 在缓存中存key value,
    	// 这里通过 key 拿到数据
        var list = _cacheCommon.GetOnlineUserListByUuid(Uuid);
        return list;
    }
	
	// 创建时 加入ip, 销毁时移除ip
    protected override void OnInitialized()
    {
    	// 这部分实现比较简单了. 真实环境, 还是建议去做的复杂一些,比如 ip不能重复 等等
        _ip = _httpContextAccessor?.HttpContext?.Connection?.RemoteIpAddress?.ToString() ?? "";

        var list = GetOnlineUserList();

        list.Add(_ip);

        // 保存IP地址
        OnlineCount = list.Count;

        // 持续更新数据 (3秒)
        _timer = new System.Threading.Timer(_ =>
        {
            // 获取Redis中当前阅读人数
            var count = GetOnlineUserList().Count;
            if (count != OnlineCount)
            {
                OnlineCount = count;
                // 通知组件已经更改, 让组件重新渲染
                InvokeAsync(StateHasChanged);
            }
        }, null, 0, 3000);
    }

	// 组件销毁时的操作
    ValueTask IAsyncDisposable.DisposeAsync()
    {
        var list = GetOnlineUserList();
		// 移除ip
        list.Remove(_ip);

        OnlineCount = list.Count;

        return _timer?.DisposeAsync() ?? ValueTask.CompletedTask;
    }
}


使用组件 ( Content.razor )

@*当前在线数量*@
@{
	// 判断是否是 Blazor服务端模式,(wasm模式就不让他渲染了.)
	// https://blog.csdn.net/qq_37214567/article/details/123228022
    if (_myUitls.IsServerMode)
    {
        <Alert ShowBar="true" Color="Color.Success">
        	// 传入文章的uuid
            <OnlineUserCount Uuid="@Uuid"></OnlineUserCount>
        </Alert>
    }
}

完整代码

https://github.com/xxxxue/BlazorJiangBlog

参考的大佬代码

https://github.com/ldqk/Masuit.MyBlogs

using System; using System.Data; using System.Text; namespace ZKXP.BLL { /// /// OnLine 的摘要说明。 /// public class OnLine { private string USERNAME; private int OFFLINEDIFF; private int REMOVEDIFF; public OnLine() { //直接在这里设定、或从配置文件中读取配置参数 ///存放用户名的Session名 USERNAME = "UserName"; ///多少分钟不活动的用户在线列表中删除 OFFLINEDIFF = 5; ///多少秒执行一次删除不活动用户 REMOVEDIFF = 30; if(System.Web.HttpContext.Current.Application["OnlineTalbe"] == null) { this.CashTableInit(); } } public void CheckOnline() { //从Application获取数据表、获取SessionID DataTable dtOnline; dtOnline = (DataTable)System.Web.HttpContext.Current.Application["OnlineTalbe"]; string sessionId = System.Web.HttpContext.Current.Session.SessionID.ToString(); //数据表中是否有我的记录 DataRow drFind = dtOnline.Rows.Find(sessionId); if(drFind != null) { //有;更新我的状态 Info.Write("更新"); drFind["LastActiveTime"] = DateTime.Now; drFind["UserWhere"] = this.AtWhere; //用户由访客状态变为了登陆会员、或反之 if(Extend.GetSession(USERNAME) != null) { drFind["VisitorName"] = Extend.GetSession(USERNAME); drFind["VisitorLevel"] = Extend.GetSession("UserLevel"); } else { drFind["VisitorName"] = "vst"; drFind["VisitorLevel"] = -1; } } else { //无;加入关于我的在线信息 Info.Write("插入"); DataRow drNew = dtOnline.NewRow(); drNew["SessionID"] = sessionId; drNew["Visit
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值