设为首页 收藏本站
查看: 2213|回复: 0

[经验分享] 一个简易Asp.net网站日志系统

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-4-12 19:53:04 | 显示全部楼层 |阅读模式
前不久在网站上看到了网站日志访问记录组件UserVisitLogsHelp开源了! 这篇博客感觉还不错,就把源码download了下来,学习一下,发现里面的代码书写和设计并不是很好,于是自己改了改。自己在测试中也发现了一点小问题,同时也记录出来。
该组件实现原理很简单:主要利用IHttpModule接口并在Web.config中的HttpModule节点添加此组件的配置,考虑到性能和可移植性,数据库采用开源Sqlite,方便维护和数据采集。这里数据采集需要一个相应的配置类,结构如下:
121756457939939.jpg
FileSource和DateSource两个属性共同决定sqllite文件名,DateSource 取值是day,month,year,表示每天、月、年一个数据库文件。比如我这里是month,生成的文件如下:
121800193725923.jpg
ExcludeUrlRegex属性主要是设置需要排除url对应的正则表达式。很多时候我们并不需要记录css、js、图片等静态资源的访问日志。
在测试的时候 建议大家不要设置Password属性,不然在用sqllite管理工具打开数据库文件时出现错误信息。如我这里用SQLlite Administrator错误信息如下:
121805534979146.jpg
整个web application必须部署到正式的IIS环境,千万不要使用IIS Express,如果你用IIS Express会出现如下错误。
121810322935639.jpg
记录的 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>

源码下载地址:金山快盘附件WebSiteVisitLog.rar(24.13MB)

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-17248-1-1.html 上篇帖子: 日志分析小脚本的实现及优化扩展 下篇帖子: mysql优化服务器设置 网站
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表