一个简易Asp.net网站日志系统
前不久在网站上看到了网站日志访问记录组件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 文件,内容如下:
<?xml version="1.0" encoding="utf-8" ?>
<WebSiteVisitLog>
<WebSiteVisit>
<!--FileSource Automatic Generation of Database File year:one year month:every month day:every day None:Does not generate -->
<SQLiteConnectings FileSource="~/App_Data/HomeWeb" Password=""
DateSource="month" WebSite="" ExcludeUrlRegex=".*\.(js|css|png)"
DecodeUrl="" TextDecoding="utf-8" ExcludeUserAgentRegex=""
WebCookiesName="" WebCookiesExpires="3650"/>
</WebSiteVisit>
</WebSiteVisitLog>
同时修改web.config文件如下:
<modules runAllManagedModulesForAllRequests="true">
<add name="WebSiteVisit" type="WebSiteVisitLog.WebSiteVisitHttpModule,WebSiteVisitLog"/>
</modules>
源码下载地址:http://download.csdn.net/detail/dz45693/7183419
一个简易Asp.net网站日志系统的更多相关文章
- 使用EF Code First搭建一个简易ASP.NET MVC网站,允许数据库迁移
本篇使用EF Code First搭建一个简易ASP.NET MVC 4网站,并允许数据库迁移. 创建一个ASP.NET MVC 4 网站. 在Models文件夹内创建Person类. public ...
- .NET 黑魔法 - asp.net core 日志系统
asp.net core 里如何记录日志呢? 这要从asp.net core的依赖注入说起,在asp.net core里的依赖注入真是无所不在,各种面向切面的接口与事件. 好吧,来点干货. 首先,我们 ...
- 用python 10min手写一个简易的实时内存监控系统
简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...
- [转]用python 10min手写一个简易的实时内存监控系统
简易的内存监控系统 本文需要有一定的python和前端基础,如果没基础的,请关注我后续的基础教程系列博客 文章github源地址,还可以看到具体的代码,喜欢请在原链接右上角加个star 腾讯视频链接 ...
- 快速搭建日志系统——ELK STACK
什么是ELK STACK ELK Stack是Elasticserach.Logstash.Kibana三种工具组合而成的一个日志解决方案.ELK可以将我们的系统日志.访问日志.运行日志.错误日志等进 ...
- 集中式日志系统 ELK 协议栈详解
简介 在我们日常生活中,我们经常需要回顾以前发生的一些事情:或者,当出现了一些问题的时候,可以从某些地方去查找原因,寻找发生问题的痕迹.无可避免需要用到文字的.图像的等等不同形式的记录.用计算机的术语 ...
- PowerJob 在线日志饱受好评的秘诀:小但实用的分布式日志系统
本文适合有 Java 基础知识的人群 作者:HelloGitHub-Salieri HelloGitHub 推出的<讲解开源项目>系列. 项目地址: https://github.com/ ...
- AngularJs打造一个简易权限系统
AngularJs打造一个简易权限系统 一.引言 上一篇博文已经向大家介绍了AngularJS核心的一些知识点,在这篇博文将介绍如何把AngularJs应用到实际项目中.本篇博文将使用AngularJ ...
- ASP.NET Core分布式日志系统ELK实战演练
一.ELK简介 ELK是Elasticsearch.Logstash和Kibana首字母的缩写.这三者均是开源软件,这三套开源工具组合起来形成了一套强大的集中式日志管理平台. • Elastics ...
随机推荐
- 一个页面从输入URL 到页面加载显示完成,这个过程中都发生了什么?
1.当发送一个URL请求时,浏览器会开启一个线程来处理这个请求,同时在远程DNS服务器上启动一个DNS查询,解析获取网址的IP地址:2.浏览器与远程Web服务器通过TCP三次握手协商来建立一个TCP/ ...
- BZOJ4317: Atm的树
Description Atm有一段时间在虐qtree的题目,于是,他满脑子都是tree,tree,tree…… 于是,一天晚上他梦到自己被关在了一个有根树中,每条路径都有边权,一个神秘的声音告诉他, ...
- String和StringBuilder、StringBuffer的区别?
估计很多Java初学者在学习Java的过程中都会遇到这个问题,那就是String,StringBuilder,StringBuffer这三个类之间有什么区别?今天在这里整理一下,希望对大家有帮助哈.如 ...
- 接口开发-集成数据库操作(mybatis)
关于数据存储,最常用的方式就是存到数据库,此篇以MySQL数据库为例,以mybatis框架完成数据库的操作. 一.添加对应依赖 <!-- 数据库:MySQL --> <depende ...
- windows pm2 开机启动
npm install pm2-windows-startup -g; pm2-startup install; pm2 kill; pm2 start ecosystem.config.js --o ...
- 用css解决table文字溢出控制td显示字数(转)
场景: 最左边这栏我不行让他换行,怎么办呢? 下面是解决办法: table{ width:100px; table-layout:fixed;/* 只有定义了表格的布局算法为fixed,下面td的定义 ...
- Java 与 .NET 的平台发展之争
Java 8即将正式发布,从早期版本中,我们已经可以领略到一些令人兴奋的特性.但是开发者Andrew C. Oliver表示,尽管如此,Java语言在某些特性上还是落后于.Net.比如,Java 8中 ...
- Delphi 包的设计思想及它与PAS、BPL、DCU、DLL、OXC的关系
一.Delphi中各种文件的介绍,及其关系. OXC: ActiveX控件.会被安装到某一个组件包DPK中,在Imports中会创建PAS.DCU.DCR三个文件. DLL: 动态链接库文件,它的Ex ...
- 认识TWICImage类
Graphics 单元新增了 TWICImage 类, 该类的功能源于新增的 Wincodec.pas 单元. WIC 支持的图像有 BMP.PNG.ICO.JPEG.GIF.TIFF.HDP(HDP ...
- mqtt介绍
MQTT是轻量级基于代理的发布/订阅的消息传输协议,它可以通过很少的代码和带宽和远程设备连接.例如通过卫星和代理连接,通过拨号和医疗保健提供者连接,以及在一些自动化或小型设备上,而且由于小巧,省电,协 ...