用戶點擊數量統計

来源:http://www.cnblogs.com/chayangge/archive/2016/12/24/6218695.html
-Advertisement-
Play Games

在微信上做一次推廣活動,頁面共計三個按鈕,需要分別統計點擊次數,pc上的相關統計用的是“百度統計”,因為H5活動頁的時效性等原因,並沒有使用百度統計,而是自己實現一個簡單的統計小方案:前端點擊時請求一個空白小gif圖,帶有參數,後端同事根據nginx請求日誌做統計,通過在cookie中存入一個不會重 ...


在微信上做一次推廣活動,頁面共計三個按鈕,需要分別統計點擊次數,pc上的相關統計用的是“百度統計”,因為H5活動頁的時效性等原因,並沒有使用百度統計,而是自己實現一個簡單的統計小方案:前端點擊時請求一個空白小gif圖,帶有參數,後端同事根據nginx請求日誌做統計,通過在cookie中存入一個不會重疊的時間戳作為key值來區分是否同一用戶(uv)。

請求的圖片存在七牛中,是固定不變的,主要變化是後面兩個參數:用戶標識uid和按鈕標識,其中生成不重覆(把重覆率降到最低)的用戶標識很有意思,可參考這篇文章

時間戳用new Date().getTime()得出一個13位的“隨機數”,精確到毫秒,但萬一同一毫秒有兩個以上用戶點擊呢?於是再嚴謹一些,用for迴圈在隨機一個5位字元串拼接,這樣的重覆率絕對夠用:

uid = new Date().getTime();
var randomNumber = '';
for(var i = 0 ; i < 5 ; i ++){
    randomNumber += new String (Math.floor(Math.random() * 10));
}
uid = uid + randomNumber;

下麵是具體邏輯代碼,當網頁中已有請求圖片時,更改url的參數也一樣能從新發起一個get請求,避免每次點擊都append一張圖片。這種實現方法感覺比點擊發送ajax更加方便。

statistics: function(position){
    var pic = "http://wx.daigj.com/notification/statistics/p.gif";
    var uid = util.readCookie("uid");
    var imgLength = $("#statistics-img").length;
    if(uid){
        if(imgLength == 0){
            $('body').append('<img id="statistics-img" src="' + pic + '?uid='+ uid + '&position='+ position +'"/>');
        }else{
            $("#statistics-img").attr("src",pic+"?uid="+uid+"&position="+position);
        }
    }else{
        uid = new Date().getTime();
        var randomNumber = '';
        for(var i = 0 ; i < 5 ; i ++){
            randomNumber += new String (Math.floor(Math.random() * 10));
        }
        uid = uid + randomNumber;
        util.createCookie("uid",uid);
        $('body').append('<img id="statistics-img" src="' + pic + '?uid='+ uid + '&position='+ position +'"/>');
    }
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、簡介 網路爬蟲(又被稱為網頁蜘蛛,網路機器人,在FOAF社區中間,更經常的稱為網頁追逐者),是一種按照一定的規則,自動地抓取萬維網信息的程式或者腳本。另外一些不常使用的名字還有螞蟻、自動索引、模擬程式或者蠕蟲。 二、requests Python標準庫中提供了:urllib、urllib2、ht ...
  • 操作系統:Win10 java版本:1.8.0_102 1、下載安裝java JDK(安裝時把jre放在了同級目錄) 地址為:F:\Program Files\Java 目錄下 2、配置環境變數 此電腦 ->右鍵“屬性” ->高級系統設置 ->環境變數 (一)在系統變數中新建:變數名:JAVA_HO ...
  • 題目大意: 給定一個n個數的序列和m個詢問(n,m<=100000)和k,每個詢問包含k+2個數字:l,r,b[1],b[2]...b[k],要求輸出b[1]~b[k]在[l,r]中是否出現。 思路:把所有連續的k個數字hash一下,然後扔進主席樹,詢問時在主席樹中查詢就可以了。 註意(坑)點:1、 ...
  • 觀察者模式由四個角色組成:抽象組件角色,抽象裝飾者角色,具體組件角色,具體裝飾者角色。 抽象組件角色:給出一個抽象介面,以規範“準備接受附加功能”的對象。 抽象裝飾者角色:持有一個組件(Component)對象的引用,並定義一個與抽象組件介面一致的介面。 具體組件角色:定義一個準備接受附加功能的類。 ...
  • renren-security是一個輕量級許可權管理系統,其核心設計目標是開發迅速、學習簡單、輕量級、易擴展;使用Spring MVC、Shiro、MyBatis、Bootstrap、Vue2.x等框架,包含:管理員管理、角色管理、菜單管理、定時任務、參數管理、代碼生成器等。 ...
  • 1.環境準備 下載mongoDB對Java支持的驅動包 驅動包下載地址:https://github.com/mongodb/mongo-java-driver/downloads 2.查詢集合中所有文檔 3.刪除集合中的文檔 4.向集合中插入文檔 5.更新集合中的文檔 ...
  • 1.概念 分片(sharding)是指將數據拆分,將其分散存在不同的機器上的過程。有時也用分區(partitioning)來表示這個概念。將數據分散到不同的機器上,不需要功能強大的大型電腦就可以儲存更多的數據,處理更多的負載。 2.分片 mongos就是一個路由伺服器,它會根據管理員設置的“片鍵” ...
  • 簡單選擇排序,是選擇排序演算法的一種。基本思想:每趟從待排序的記錄中選出關鍵字最小的記錄,順序放在已排序的記錄序列末尾,直到全部排序結束為止。由於在每次迴圈中,會對數值相等的元素改變位置,所以屬於非穩定排序。 如下圖所示: 對簡單選擇排序的優化方案,是採用二元選擇排序,即將其改進為每趟迴圈確定兩個元素 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...