随笔 - 165, 文章 - 0, 评论 - 18, 阅读 - 22万
  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

网站来访者IP及地址记录

Posted on   火冰·瓶  阅读(2449)  评论(0编辑  收藏  举报

将此段代码放入网站的母版页或者header的用户控件中。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
private void AccessRecord()
{
    string ip = Request.UserHostAddress;
    string ipDataPath = Server.MapPath("QQWry.Dat");//纯真ip数据库http://www.cz88.net       
    Fireicesion.WebTools.IpAddressSearch ipSearch = new Fireicesion.WebTools.IpAddressSearch(ipDataPath);//前一篇随笔中的根据ip获取地址
    string address = ipSearch.GetAddressWithIP(ip);
    if (CheckRecord(ip))
    {
        string sql = "insert into AccessRecord (ip,address,recordtime) values('" + ip + "','" + address + "','" + DateTime.Now.ToString() + "')";
        DB.Insert(sql);
    }
}
 
 
/// <summary>
/// 上次访问时间,true可记录,false不记录
/// </summary>
/// <param name="ip"></param>
/// <returns></returns>
private bool CheckRecord(string ip)
{
    string sql = "select * from AccessRecord where ip='" + ip + "' order by RecordTime desc limit 0,1";
    DataTable dt = DB.GetDataTable(sql);
    if (dt.Rows.Count == 0)//没有找到记录,此IP未曾访问过
        return true;
    else
    {
        DateTime lastTime = Convert.ToDateTime(dt.Rows[0]["RecordTime"]);
        DateTime now = DateTime.Now;
        TimeSpan timeSpan = new TimeSpan(0, 30, 0);//半个小时内访问不重复记录
        if (lastTime.Add(timeSpan).CompareTo(now) == -1)
        {
            return true;
        }
        return false;
    }
}

数据库表(MySql格式的)

1
2
3
4
5
6
7
CREATE TABLE `accessrecord` (
  `Id` int(11) NOT NULL AUTO_INCREMENT,
  `Ip` varchar(80) DEFAULT NULL,
  `Address` varchar(100) DEFAULT NULL,
  `Recordtime` datetime DEFAULT '2000-01-01 00:00:00',
  PRIMARY KEY (`Id`)
) ENGINE=InnoDB AUTO_INCREMENT=58 DEFAULT CHARSET=utf8;
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示