为了了解网站的访问情况,很多网站用了第三方的统计,比如google统计,百度统计,51.la,CNZZ等,但是统计的准确性不能而之,有的网站干脆放多个第三方的统计,以便做个比较,得到更准确的结果。
根据笔者对第三方统计的使用经验,第一:第三方统计有一定的水分存在,第二:因为具有通用性,并不能得到个性化的统计结果。第三:无法确定某个推广源的统计信息。因为这种问题的存在,公司有新的需要,便开发了一个简单的推广访问记录功能。
说起来并不复杂,只要用Ajax方法在后台添加访问记录即可,系统并没有根据Cookie来做跟踪记录,只是根据ip来,所以统计结果上可能有点出入,会少统计些。如果要更真实的统计结果,还是根据cookie统计为好,好了,下面就来介绍这个功能的实现。
思路是这样的,页面中只有加入一个js文件,就能统计到该页面的访问信息,如果运用了模板功能,就只要在模板中加入此js即可,此js我们暂命名为visit.js,放在根目录下,建议链接放在页面的底部即可。js文件里通过xmlhttPRequest这个对象把访问记录信息添加到数据库Visit表中,表设计的字段如下:
下面来介绍js的实现,js方法需异步调用后台方法,这个文件我们定义为AJAX.aspx,方法比较简单,就是获取js文件当中传递过来的参数,然后添加到数据库中去。
js中代码如下:
1 Visit.js 2 3 var req; 4 var visitID; 5 creatReq(); 6 7 function creatReq() { 8 9 // 获取当前网站的更目录,这比较重要,全局通用的保证 10 var path = getRootPath(); 11 // 后台处理的文件地址,注意,必须把这个文件的前台页面大部分清空,只留下第一行 12 var url = path + "AJAX.aspx"; 13 14 if (window.xmlhttpRequest) { 15 req = new XMLHttpRequest; 16 } 17 else if (window.ActiveXObject) { 18 req = new ActiveXObject("Microsoft.XMLHttp"); 19 } 20 if (req) { 21 // 获取当前的网址 22 var link = window.location.href; 23 // 获取上页地址 24 var oldlink = document.referrer; 25 // 获取当前访问页的标题 26 var titleName = document.title; 27 // 屏幕分辨率 28 var screen = window.screen.width + "*" + window.screen.height; 29 // 异步请求发送 30 req.open("GET", url + "?id=" + escape(link) + "&oldlink=" + escape(oldlink) + "&title=" + escape(titleName) + "&sys=" + getSysInfo() + "&s=" + screen + "&b=" + GetBrowserType() + " " + GetBrowserVersion() + "&p=" + remote_ip_info.province + "&c=" + remote_ip_info.city + "&k=" + GetKeyWord(oldlink), true); 31 req.onreadystatechange = callback; // 制定回调函数 32 req.send(null); 33 } 34 } 35 36 // 获取当前网站的更目录,这比较重要,全局通用的保证 37 function getRootPath() { 38 return window.location.protocol + "//" + window.location.host + "/"; 39 } 40 41 42 // 获取来自搜索引擎的关键词 43 function GetKeyword(url) { 44 if (url.toString().indexOf("baidu") > 0) { 45 return request(url, "wd"); 46 } 47 else if (url.toString().indexOf("google") > 0) { 48 return request(url, "q"); 49 } 50 else if (url.toString().indexOf("sogou") > 0) { 51 return request(url, "query"); 52 } 53 else if (url.toString().indexOf("soso") > 0) { 54 return request(url, "w"); 55 } 56 else { 57 return ""; 58 } 59 } 60 61 // 获取链接地址中某个参数的值 62 function request(url, paras) { 63 var paraString = url.substring(url.indexOf("?") + 1, url.length).split("&"); 64 var paraObj = {} 65 for (i = 0; j = paraString[i]; i++) { 66 paraObj[j.substring(0, j.indexOf("=")).toLowerCase()] = j.substring(j.indexOf("=") + 1, j.length); 67 } 68 var returnValue = paraObj[paras.toLowerCase()]; 69 if (typeof (returnValue) == "undefined") { 70 return ""; 71 } else { 72 return returnValue; 73 } 74 } 75 76 77 // 回调函数,可以获取添加后的访问ID,以便其他操作。 78 function callback() { 79 if (req.readyState == 4) { 80 if (req.status == 200) { 81 visitID = req.responseText.toString(); 82 } 83 else { 84 85 } 86 } 87 else { 88 89 } 90 } 91 92 93 // 获取系统信息 94 function getSysInfo() { 95 96 var ua = navigator.userAgent.toLowerCase(); 97 isWin7 = ua.indexOf("nt 6.1") > -1 98 isVista = ua.indexOf("nt 6.0") > -1 99 isWin2003 = ua.indexOf("nt 5.2") > -1100 isWinXp = ua.indexOf("nt 5.1") > -1101 isWin2000 = ua.indexOf("nt 5.0") > -1102 isWindows = (ua.indexOf("windows") != -1 || ua.indexOf("win32") != -1)103 isMac = (ua.indexOf("macintosh") != -1 || ua.indexOf("mac os x") != -1)104 isAir = (ua.indexOf("adobeair") != -1)105 islinux = (ua.indexOf("linux") != -1)106 var broser = "";107 if (isWin7) {108 sys = "Windows 7";109 } else if (isVista) {110 sys = "Vista";111 } else if (isWinXp) {112 sys = "Windows xp";113 } else if (isWin2003) {114 sys = "Windows 2003";115 } else if (isWin2000) {116 sys = "Windows 2000";117 } else if (isWindows) {118 sys = "Windows";119 } else if (isMac) {120 sys = "Macintosh";121 } else if (isAir) {122 sys = "Adobeair";123 } else if (isLinux) {124 sys = "Linux";125 } else {126 sys = "Unknow";127 }128 return sys;129 }130 131 // 获取浏览器类型132 function GetBrowserType() {133 134 var ua = navigator.userAgent.toLowerCase();135 136 if (ua == null) return "ie";137 138 else if (ua.indexOf('Chrome') != -1) return "chrome";139 140 else if (ua.indexOf('Opera') != -1) return "opera";141 142 else if (ua.indexOf('msie') != -1) return "ie";143 144 else if (ua.indexOf('safari') != -1) return "safari";145 146 else if (ua.indexOf('Firefox') != -1) return "firefox";147 148 else if (ua.indexOf('gecko') != -1) return "gecko";149 150 else return "ie";151 152 }153 154 // 获取浏览器版本155 function GetBrowserVersion() {156 157 var ua = navigator.userAgent.toLowerCase();158 159 if (ua == null) return "null";160 161 else if (ua.indexOf('chrome') != -1) return ua.substring(ua.indexOf('chrome') + 7, ua.length).split(' ')[0];162 163 else if (ua.indexOf('opera') != -1) return ua.substring(ua.indexOf('version') + 8, ua.length);164 165 else if (ua.indexOf('msie') != -1) return ua.substring(ua.indexOf('msie') + 5, ua.length - 1).split(';')[0];166 167 else if (ua.indexOf('safari') != -1) return ua.substring(ua.indexOf('safari') + 7, ua.length);168 169 else if (ua.indexOf('gecko') != -1) return ua.substring(ua.indexOf('firefox') + 8, ua.length);170 171 else return "null";172 173 }Visit.js
这里有一个特殊说明,根据IP来获取省份和城市信息,目前用的是新浪提供的js文件,没有用网上流传的IP库信息,用新浪的这个js有时候获取的是乱码信息,这个问题偶尔会出现。
这是新浪的地址引用:<script language='javascript' type='text/Javascript' src='http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js'></script>
下面说后台,AJAX.aspx文件的前台删除大部分内容,只留下第一行信息,后台就是获取js传递过来的信息,代码如下:
AJAX.ASPX//放在Page_load里面的内容 visitModel.VisitReferrer = Request.QueryString["oldlink"].ToString() ; visitModel.VisitReferrerType = int.Parse(GetVisitReferrerType(Request.QueryString["oldlink"].ToString())); visitModel.VisitResolution = Request.QueryString["s"].ToString(); visitModel.VisitURL = Request.QueryString["id"].ToString(); visitModel.VisitTimeIn = System.DateTime.Now; visitModel.VisitIP = GetClientIP(); visitModel.VisitOS = Request.QueryString["sys"].ToString(); visitModel.VisitURLTitle = Request.QueryString["title"].ToString(); visitModel.VisitBrowserType = Request.QueryString["b"].ToString(); visitModel.VisitReferrerKeywords = ; visitModel.VisitProvince = Request.QueryString["p"].ToString(); visitModel.VisitCity = Request.QueryString["c"].ToString(); // 获取source后面的内容] string url = Request.QueryString["id"].ToString(); if (ur
新闻热点
疑难解答