前不久在网站上看到了网站日志访问记录组件UserVisitLogsHelp开源了! 这篇博客感觉还不错,就把源码download了下来,学习一下,发现里面的代码书写和设计并不是很好,于是自己改了改。自己在测试中也发现了一点小问题,同时也记录出来。

该组件实现原理很简单:主要利用IHttpModule接口并在Web.config中的HttpModule节点添加此组件的配置,考虑到性能和可移植性,数据库采用开源Sqlite,方便维护和数据采集。这里数据采集需要一个相应的配置类,结构如下:

FileSource和DateSource两个属性共同决定sqllite文件名,DateSource 取值是day,month,year,表示每天、月、年一个数据库文件。比如我这里是month,生成的文件如下:

ExcludeUrlRegex属性主要是设置需要排除url对应的正则表达式。很多时候我们并不需要记录css、js、图片等静态资源的访问日志。

在测试的时候 建议大家不要设置Password属性,不然在用sqllite管理工具打开数据库文件时出现错误信息。如我这里用SQLlite Administrator错误信息如下:

整个web application必须部署到正式的IIS环境,千万不要使用IIS Express,如果你用IIS Express会出现如下错误。

记录的 Sqlite日志数据库 结构如下:

编号

字段名称

字段类型

备注

1

Id

integer

自增序号(PK,Not Null)

2

UserHostAddress

varchar(20)

远程客户端的IP主机地址

3

UserHostName

varchar(20)

远程客户端的DNS名称

4

UrlAbsoluteUri

varchar(1600)

当前请求的绝对URI

5

PhysicalPath

varchar(500)

当前请求的URL相对应的物理文件路径

6

UserAgent

varchar(1000)

客户端浏览器的原始用户代理信息

7

HttpMethod

varchar(4)

客户端使用的HTTP数据传输方法

8

UserLanguages

varchar(20)

客户端语言首选项的排序字符

9

UrlHost

varchar(100)

客户端主机的实例名

10

UrlPort

varchar(10)

当前URI的端口号

11

TotalBytes

integer

当前输入流中的字节数

12

ContentLength

integer

客户端发送的内容长度(以字节计)

13

IsLocal

varchar(5)

当前请求是否来自本地计算机

14

BrowserType

varchar(30)

浏览器的名称和主(整数)版本号

15

BrowserVersion

varchar(20)

浏览器的完整版本号(包括整数和小数)

16

BrowserPlatform

varchar(20)

客户端使用的操作系统平台名称

17

BrowserBeta

varchar(5)

浏览器是否为测试版

18

BrowserActiveXControls

varchar(5)

浏览器是否支持ActiveX控件

19

BrowserCookies

varchar(5)

浏览器是否支持Cookie

20

BrowserCrawler

varchar(5)

浏览器是否为Web爬行遍历搜索引擎

21

BrowserJavaScript

varchar(5)

浏览器支持的EcmaScript主版本号

22

BrowserSupportsXmlHttp

varchar(5)

浏览器是否支持通过HTTP接收XML

23

BrowserInputType

varchar(30)

浏览器支持的输入类型

24

BrowserScreenPixelsWidth

integer

浏览器显示的近似宽度(单位像素)

25

BrowserScreenPixelsHeight

integer

浏览器显示的近似高度(单位像素)

26

UrlReferrerAbsoluteUri

varchar(1600)

客户端上次请求(该请求链接当前的URL)的绝对URI

27

UrlReferrerAbsoluteUriDecode

varchar(1600)

对UrlReferrerAbsoluteUri字段进行zh-cn或utf-9解码

28

UrlReferrerHostName

varchar(100)

客户端上次请求(该请求链接当前的URL)的DNS名称

29

CanCombineFormsInDeck

varchar(5)

浏览器是否支持包括多个窗口的卡片组

30

IsMobileDevice

varchar(5)

浏览器是否为已识别的移动设备

31

MobileDeviceManufacturer

varchar(30)

已知移动设备制造商的名称

32

MobileDeviceModel

varchar(30)

已知移动设备的型号名

33

NumberOfSoftkeys

integer

移动设备上软键的数目

34

ContentEncoding

varchar(10)

内容字符的编码

35

ScreenBitDepth

integer

浏览器显示的近似深度(单位像素)

36

Website

varchar(100)

访问Web站点

37

WebCookies

varchar(80)

记录当前访客的惟一Cookies值

38

VisitTime

varchar(20)

当前请求访问时间

至于使用方式我想很简单,在系统根目录下创建一个WebSiteVisitConfig.xml 文件,内容如下:

  1. <?xml version="1.0" encoding="utf-8" ?>
  2. <WebSiteVisitLog>
  3. <WebSiteVisit>
  4. <!--FileSource Automatic Generation of Database File year:one year month:every month day:every day None:Does not generate -->
  5. <SQLiteConnectings FileSource="~/App_Data/HomeWeb" Password=""
  6. DateSource="month" WebSite="" ExcludeUrlRegex=".*\.(js|css|png)"
  7. DecodeUrl="" TextDecoding="utf-8" ExcludeUserAgentRegex=""
  8. WebCookiesName="" WebCookiesExpires="3650"/>
  9. </WebSiteVisit>
  10. </WebSiteVisitLog>

同时修改web.config文件如下:

  1. <modules runAllManagedModulesForAllRequests="true">
  2. <add name="WebSiteVisit" type="WebSiteVisitLog.WebSiteVisitHttpModule,WebSiteVisitLog"/>
  3. </modules>

源码下载地址:http://download.csdn.net/detail/dz45693/7183419

一个简易Asp.net网站日志系统的更多相关文章

  1. 使用EF Code First搭建一个简易ASP.NET MVC网站,允许数据库迁移

    本篇使用EF Code First搭建一个简易ASP.NET MVC 4网站,并允许数据库迁移. 创建一个ASP.NET MVC 4 网站. 在Models文件夹内创建Person类. public ...

  2. .NET 黑魔法 - asp.net core 日志系统

    asp.net core 里如何记录日志呢? 这要从asp.net core的依赖注入说起,在asp.net core里的依赖注入真是无所不在,各种面向切面的接口与事件. 好吧,来点干货. 首先,我们 ...

  3. 用python 10min手写一个简易的实时内存监控系统

    简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...

  4. [转]用python 10min手写一个简易的实时内存监控系统

    简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...

  5. 快速搭建日志系统——ELK STACK

    什么是ELK STACK ELK Stack是Elasticserach.Logstash.Kibana三种工具组合而成的一个日志解决方案.ELK可以将我们的系统日志.访问日志.运行日志.错误日志等进 ...

  6. 集中式日志系统 ELK 协议栈详解

    简介 在我们日常生活中,我们经常需要回顾以前发生的一些事情:或者,当出现了一些问题的时候,可以从某些地方去查找原因,寻找发生问题的痕迹.无可避免需要用到文字的.图像的等等不同形式的记录.用计算机的术语 ...

  7. PowerJob 在线日志饱受好评的秘诀:小但实用的分布式日志系统

    本文适合有 Java 基础知识的人群 作者:HelloGitHub-Salieri HelloGitHub 推出的<讲解开源项目>系列. 项目地址: https://github.com/ ...

  8. AngularJs打造一个简易权限系统

    AngularJs打造一个简易权限系统 一.引言 上一篇博文已经向大家介绍了AngularJS核心的一些知识点,在这篇博文将介绍如何把AngularJs应用到实际项目中.本篇博文将使用AngularJ ...

  9. ASP.NET Core分布式日志系统ELK实战演练

    一.ELK简介  ELK是Elasticsearch.Logstash和Kibana首字母的缩写.这三者均是开源软件,这三套开源工具组合起来形成了一套强大的集中式日志管理平台. •  Elastics ...

随机推荐

  1. Oracle的一些初步小东西

    经常要用数据库,让他自己启动的话,开机太慢,所以用命令启动方便点.  1.开启:    在运行中输入cmd,进入控制台,lsnrctl start回车,提示启动监听成功后net start Oracl ...

  2. bzoj 3285 离散对数解指数方程

    /************************************************************** Problem: 3285 User: idy002 Language: ...

  3. 【转载】gdi+ 内存泄漏

    [转载]http://issf.blog.163.com/blog/static/1941290822009111894413472/ 最近用GDI+实现了几个自定义控件,但是发现存在内存泄露问题 B ...

  4. ROS知识(21)----ROS C++代码格式化

    这里提供两种方法. 第一种方法:clang_format 1.安装clang format sudo apt-get install -y clang-format-3.6 2.从github的ros ...

  5. API测试利器postMan 使用教程

    自从开始做API开发之后,我就在寻找合适的API测试工具.一开始不是很想用Chrome扩展,用的 WizTools 的工具,后来试过一次 Postman 之后就停不下来了,还买了付费的Jetpacks ...

  6. Hadoop化繁为简(一)-从安装Linux到搭建集群环境

    简介与环境准备 hadoop的核心是分布式文件系统HDFS以及批处理计算MapReduce.近年,随着大数据.云计算.物联网的兴起,也极大的吸引了我的兴趣,看了网上很多文章,感觉还是云里雾里,很多不必 ...

  7. ActiveMQ_ActiveMQ安装与配置

    ActiveMQ安装与配置   1.环境: Windows XP apache-activemq-5.2.0-bin.zip   2.安装 解压缩到apache-activemq-5.2.0-bin. ...

  8. hdoj-2066-一个人的旅行(迪杰斯特拉)

    一个人的旅行 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Sub ...

  9. JPA & Hibernate 注解

    1 . @Entity(name="EntityName") 必须 ,name 为可选 , 对应数据库中一的个表 2 . @Table(name="",cata ...

  10. Oracle 备份、恢复单表或多表数据步骤

    Oracle 备份.恢复单表或多表数据步骤,适用于 Oracle 8.9.10.        *备份单表或多表数据: exp user/password@server file=filefullpa ...