网站日志访问记录组件UserVisitLogsHelp开源了!
之前在《一种基于自定义代码记录用户访问日志在Sharepoint网站的应用方法!》一文利用本人几年前的开发的UserVisitLogsHelp组件进行了网站用户访问日志记录,可用于网站分析,虽然IIS可以有日志记录的功能(也可通过工具分析),但它的主要缺点是可定制性相对较差,难以满足个性化的需求,只能用于windows平台的站点,有很大的局限性。通过该组件不仅能用于asp.net等windows平台网站,也可以用于PHP、JSP等Linux网站。该组件目前已在Codeplex网站中开源了,具体网址如下:http://uservisitlogshelp.codeplex.com/。
该组件实现原理很简单:主要利用IHttpModule接口并在Web.config中的HttpModule节点添加此组件的配置,考虑到性能和可移植性,数据库采用开源Sqlite,方便维护和数据采集。
Sqlite日志数据库网站用户访问日志表(UserVisitLog)结构设计如下:
|
编号 |
字段名称 |
字段类型 |
备注 |
|
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) |
当前请求访问时间 |
三种典型的应用场景:
<add name="WebsiteVisit" type="NetOpen_System.Component.WebsiteVisitHttpModule, NetOpen_System.Component.WebsiteVisit"/>
</httpModules>
SP.SOD.executeOrDelayUntilScriptLoaded(runMyCode, "SP.js");
var currentUser = null;
var currentUserTitle=null;
function runMyCode() {
var ctx = new SP.ClientContext.get_current();
var web = ctx.get_web();
ctx.load(web);
var user = web.get_currentUser();
user.retrieve();
ctx.executeQueryAsync(
function () {
//only in the success case you can work with user login
currentUser= user.get_loginName();
currentUserTitle = user.get_title();
document.getElementById("randimg").src="http://webloggersite/Default.aspx?UserName=" +currentUser+"&UserTitle="+currentUserTitle;
},
function (data) {
//notify the failure
});
}
</script>
<img id="randimg" name="randimg" src="" style="width:0;height:0;" />
function addImg(isrc) {
var Img = new Image();
Img.style = "width:0;height:0;";
Img.onload = function () {
document.body.appendChild(Img);
}
Img.src = isrc;
}
addImg("http://webloggersite/Default.aspx");
</script>
<img id="randimg" name="randimg" src="" style="width:0;height:0;" />
<NetOpen_System>
<WebsiteVisit>
<!--DateSource Automatic Generation of Database File year:one year month:every month day:every day None:Does not generate -->
<SQLiteConnectings DataSource="~/Visit_Data/HomeWeb" Password="12345678" DateSource="day" Website="" ExcludeUrl="" DecodeUrl="" TextDecoding="utf-8" ExcludeUserAgent="" WebCookiesName="" WebCookiesExpires="3650"/>
</WebsiteVisit>
</NetOpen_System>
|
本博客为软件人生原创,欢迎转载,转载请标明出处:http://www.cnblogs.com/nbpowerboy/p/3158507.html。演绎或用于商业目的,但是必须保留本文的署名软件人生(包含链接)。如您有任何疑问或者授权方面的协商,请给我留言。SharePoint商业智能技术QQ群:140668362,.Net技术交流QQ群:195516928,欢迎各位加入交流。 |
网站日志访问记录组件UserVisitLogsHelp开源了!的更多相关文章
- Shell 命令行统计 apache 网站日志访问IP以及IP归属地
Shell 命令行统计 apache 网站日志访问IP以及IP归属地 我的一个站点用 apache 服务跑着,积攒了很多的日志.我想用 shell 看看有哪些人访问过我的站点,并且他来自哪里. 因为日 ...
- 一个简易Asp.net网站日志系统
前不久在网站上看到了网站日志访问记录组件UserVisitLogsHelp开源了! 这篇博客感觉还不错,就把源码download了下来,学习一下,发现里面的代码书写和设计并不是很好,于是自己改了改.自 ...
- log4net--不可多得的开源日志记录组件
log4net--不可多得的开源日志记录组件 1 前奏 一直在用log4net日志工具,却没时间写个日志给大家分享一下这个工具,趁最近比较空些,好好分享一下这个工具. 2 说明 Log4net介绍就不 ...
- Elmah 日志记录组件
http://www.cnblogs.com/jys509/p/4571298.html 简介 ELMAH(Error Logging Modules and Handlers)错误日志记录模块和处理 ...
- Linux centos7 VMware Apache访问日志不记录静态文件、访问日志切割、静态元素过期时间
一.Apache访问日志不记录静态文件 网站大多元素为静态文件,如图片.css.js等,这些元素可以不用记录 vim /usr/local/apache2.4/conf/extra/httpd-vho ...
- 【干货】.NET开发通用组件发布(四) 日志记录组件
组件介绍和合作开发 http://www.cnblogs.com/MrHuo/p/MrHuoControls.html 日志记录组件功能介绍 通过基类Logger,实现了文本记录日志和数据库记录日志两 ...
- MVC使用 Elmah 日志记录组件
在后台管理中,有一些操作是需要增加操作日志的,尤其是对一些比较敏感的金额类的操作,比如商城类的修改商品金额.删除商品.赠送金额等人工的操作.日志中记录着相关操作人的操作信息,这样,出了问题也容易排查. ...
- ASP.NET Core 实战:使用 NLog 将日志信息记录到 MongoDB
一.前言 在项目开发中,日志系统是系统的一个重要组成模块,通过在程序中记录运行日志.错误日志,可以让我们对于系统的运行情况做到很好的掌控.同时,收集日志不仅仅可以用于诊断排查错误,由于日志同样也是大量 ...
- NET Core 实战:使用 NLog 将日志信息记录到 MongoDB
NET Core 实战:使用 NLog 将日志信息记录到 MongoDB https://www.cnblogs.com/danvic712/p/10226557.html ASP.NET Core ...
随机推荐
- 59. 螺旋矩阵 II
给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, ...
- 理解Linux的进程,线程,PID,LWP,TID,TGID
在Linux的top和ps命令中,默认看到最多的是pid (process ID),也许你也能看到lwp (thread ID)和tgid (thread group ID for the threa ...
- shell if [ -d filename]
[ -a FILE ] 如果 FILE 存在则为真. [ -b FILE ] 如果 FILE 存在且是一个块特殊文件则为真. [ -c FILE ] 如果 FILE 存在且是一个字特殊文件则为真. [ ...
- 批量导入--EasyPOIPOI
easypoi功能如同名字easy,主打的功能就是容易,让一个没见接触过poi的人员 就可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 语言( ...
- Substring with Concatenation of All Words 题解
题意 You are given a string, s, and a list of words, words, that are all of the same length. Find all ...
- python开发_thread_线程_搜索本地文件
在之前的blog中,曾经写到过关于搜索本地文件的技术文章 如: java开发_快速搜索本地文件_小应用程序 python开发_搜索本地文件信息写入文件 下面说说python中关于线程来搜索本地文件 利 ...
- Codeforces Round #356 (Div. 1) D. Bear and Chase 暴力
D. Bear and Chase 题目连接: http://codeforces.com/contest/679/problem/D Description Bearland has n citie ...
- 0056 Spring MVC如何接收浏览器传递来的请求参数--request--形参--实体类封装
浏览器总会向服务器传递一些参数,那么Spring MVC如何接收这些参数? 先写个简单的html,向服务器传递一些书籍信息,如下: <!DOCTYPE html> <html> ...
- MySQL Proxy 实现MySQLDB 读写分离
一.简述 MySQL Proxy是一个处于你的client端和MySQL server端之间的简单程序,它可以监测.分析或改变它们的通信.它使用灵活,没有限制,常见的用途包括:负载平衡,故障.查询分析 ...
- CentOS使用chkconfig增加开机服务提示service xxx does not support chkconfig的问题解决
在shell文件的第二行增加如下内容即可: # chkconfig: 2345 10 90 #服务必须在运行级2,3,4,5下被启动或关闭,启动的优先级是90,关闭的优先级是10. # descrip ...