统计用户访问日志

吕津 2014-08-19 01:37:29
统计用户访问的每个页面URL、进入页面的时间StartTime、关闭页面的时间EndTime.

需要注意:
(1)不记录页面回传(比如点击了页面按钮)

...全文
248 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
吕津 2014-08-19
  • 打赏
  • 举报
回复
吕津 2014-08-19
  • 打赏
  • 举报
回复
引用 2 楼 chz415767975 的回复:
关闭页面的时间EndTime.这个很难控制,用户关闭浏览器右上角的那个叉叉,不会产生数据日志记录的







<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs" Inherits="InMainWebSite.WebForm1" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>

<script src="jquery-1.3.2.min.js" type="text/javascript"></script>

<script src="PageView.js" type="text/javascript"></script>

<script type="text/javascript">
window.onload = function() {

var obj = document.getElementById("inputFlag");

if (obj.value.length == 0) {
var guid = newGuid();
obj.value = guid;
var url = window.location.href; ;
LogPageView("begin", guid, url);
}
}

window.onbeforeunload = function() {

var obj = document.getElementById("inputFlag");

if (obj.value.length > 0) {
var guid = obj.value;
var url = window.location.href;
LogPageView("end", guid, url);
}
}

</script>

</head>
<body>
<form id="form1" runat="server">
<div>
<input type="hidden" id="inputFlag" runat="Server" />
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
<input type="button" id="Hidden1" onclick="Show()" />
</div>
</form>
</body>
</html>





function newGuid() {
var guid = "";
for (var i = 1; i <= 32; i++) {
var n = Math.floor(Math.random() * 16.0).toString(16);
guid += n;
if ((i == 8) || (i == 12) || (i == 16) || (i == 20))
guid += "-";
}
return guid;
}

function LogPageView(pageViewType, guid, url) {

if (pageViewType.toLowerCase() == "begin" || pageViewType.toLowerCase() == "end") {
var CookieUserID = document.getElementById("CookieUserID");

var userID = "";
if (document.getElementById("CookieUserID")) {
userID = document.getElementById("CookieUserID").innerHTML;
}

var urlStr = "/Cart/WebServices/PageView.ashx?pageViewType=" + pageViewType + "&guid=" + guid + "&userID=" + userID + "&url=" + url;

$.ajax({
type: "POST",
url: urlStr,
contentType: "application/json; charset=utf-8",
data: "{}",
dataType: 'xml',
success: function(msg) {
try {

}
catch (e) {
//alert(e);
return;
}
},
error: function(result, status) {
if (status == 'error') {
// alert(status);
}
}
});
}

}



using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Text;
using ZY.Cart.Presentation.Presenters;
using ZY.Cart.Model;

namespace InMainWebSite.WebServices
{
/// <summary>
/// $codebehindclassname$ 的摘要说明
/// </summary>
[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
public class PageView : IHttpHandler
{

public void ProcessRequest(HttpContext context)
{
string type = string.IsNullOrEmpty(context.Request.QueryString["pageViewType"]) ? string.Empty : context.Request.QueryString["pageViewType"].Trim().ToLower();
if(type.Length> 0)
{
PageViewInfo pageViewInfo = new PageViewInfo();
pageViewInfo.Guid = string.IsNullOrEmpty(context.Request.QueryString["guid"]) ? string.Empty : context.Request.QueryString["guid"];
pageViewInfo.UserID = string.IsNullOrEmpty(context.Request.QueryString["userID"]) ? string.Empty : context.Request.QueryString["userID"];
pageViewInfo.Url = string.IsNullOrEmpty(context.Request.QueryString["url"]) ? string.Empty : context.Request.QueryString["url"];
pageViewInfo.IP = PageHelper.IP;
if(type=="begin")
{
PageViewPresenter _presenter = new PageViewPresenter();
_presenter.CreatePageView(pageViewInfo);
}
else if (type == "end")
{
PageViewPresenter _presenter = new PageViewPresenter();
_presenter.UpdatePageView(pageViewInfo);
}
}
}

public bool IsReusable
{
get
{
return false;
}
}
}
}

吕津 2014-08-19
  • 打赏
  • 举报
回复
引用 1 楼 shangdi_zhishou 的回复:
页面loaded unloaded 写日志
网站中有很多页面(几十上百),这种方式不可取。有没有全局控制的?
霜寒月冷 2014-08-19
  • 打赏
  • 举报
回复
关闭页面的时间EndTime.这个很难控制,用户关闭浏览器右上角的那个叉叉,不会产生数据日志记录的 !
_上帝之手 2014-08-19
  • 打赏
  • 举报
回复
页面loaded unloaded 写日志

62,041

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧