關於搭建簡易郵箱驗證服務的一些想法

来源:http://www.cnblogs.com/hwding/archive/2017/06/14/7011403.html
-Advertisement-
Play Games

情境 server可以定時為用戶推送一些資料,現在需要用戶輸入郵箱,經過驗證後將其納入發送列表以便向此郵箱提供服務。 沒什麼新穎的技術,事先也沒有查閱相關資料,只是一些搭建簡易驗證流程的想法。 如果有更靠譜的或者更簡單的也可以comment。 關於驗證流程 郵箱地址有效性驗證 這個問題應該困擾過很多 ...


情境

server可以定時為用戶推送一些資料,現在需要用戶輸入郵箱,經過驗證後將其納入發送列表以便向此郵箱提供服務。

沒什麼新穎的技術,事先也沒有查閱相關資料,只是一些搭建簡易驗證流程的想法。

如果有更靠譜的或者更簡單的也可以comment。

關於驗證流程

郵箱地址有效性驗證

這個問題應該困擾過很多人,一般情況下的解決方案是使用正則表達式去匹配郵箱格式。

但是我這種不精通Regex的人大概不想這麼做,所以使用了最為暴力的方法:

Just send them an email already.

出自文章:Stop Validating Email Addresses With Regex,(義正言辭地偷懶,哈哈,畢竟最原始的方法才是最好用的,郵箱的各種奇葩合法格式很難匹配全吧,容易誤傷。

這樣就自然而然地引出了下麵一個問題,我們需要給用戶一個鏈接訪問server,server驗證此鏈接所帶param的特征去激活這個郵箱。

通過鏈接激活相應郵箱

0x0 Hash

用一個專門存放待驗證郵箱的資料庫表。

首先用戶填入了郵箱[email protected],server計算其hash之後將其存入表中:

{
    "mailbox": "[email protected]",
    "hash": "7DAF6C79D4802916D83F6266E24850AF"
}

向用戶發送鏈接:

https://yourserver.com/api/v1/validate?hash=7DAF6C79D4802916D83F6266E24850AF

用戶點擊後,server用這個hash把待驗證的email地址查出來,挪到服務列表裡。

0x1 Encrypt -> Derypt (or Encode -> Decode)

這種方式就是不使用一個中間資料庫表,直接用加密函數&密鑰去加密郵箱地址,然後發給這個郵箱:

https://yourserver.com/api/v1/validate?secret=s7dz5rt3y1u6ijkl7mn8b9hgvj96frrnagpkfg93gs51

(以上密文是臉滾鍵盤生成的,僅供示例。

用戶點擊之後server再將密文用秘鑰解密得到郵箱地址,將其加入服務列表。

關於驗證時機

先驗證,後服務

使用一些別的網站的時候,感覺大多數都是用的這種,畢竟使用郵箱註冊的賬號必須要求賬號名有效,上面設想的兩種流程也屬於驗證後再服務。

先服務,後驗證

對於一些對郵箱地址有效性要求並不那麼高的服務來說,比如訂閱資訊等,不需要用戶立即去驗證郵箱就可立即提供一段時間的服務。

這樣只需要一個表,在表中設置一個狀態validated即可,也便於用戶退訂服務的狀態更改,如果用hash法,只需要直接新建:

{
    "mailbox": "[email protected]",
    "hash": "7DAF6C79D4802916D83F6266E24850AF",
    "validated": false
}

驗證成功後再將validatedtrue

加密解密(編碼解碼)的話就存:

{
    "mailbox": "[email protected]",
    "validated": false
}

不過這樣好像就跟不需要預先存郵箱地址的初衷衝突了,不過考慮到這種服務方式只需要一張表,也就沒那麼虧了。

那麼超期仍未驗證的郵箱怎麼辦呢,我們可以跑一個Batch定期檢查,把逾期的記錄從服務表中移除。

同樣,先驗證後服務的待驗證列表也可以用這種方式移除逾期未驗證的郵箱,但是加解密(編解碼)的方式因為沒有中間狀態所以也沒有辦法判斷是否逾期了。

如果想獲得簡單且更加靈活的驗證方式也可以嘗試組合本文中的各種流程。


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

-Advertisement-
Play Games
更多相關文章
  • 1. os.path.driname(path):返迴路徑的上一級路徑字元串。 >>> os.path.dirname('D:\Games') 'D:\\' >>> 2. os.path.basename(path):返迴路徑的最後一級目錄名(文件夾名)或文件名(全稱)。 >>> os.path.b ...
  • 早在去年八月份PowerShell就開始開源跨平臺了,但是一直沒有去嘗試,叫做PowerShell Core。 這裡打算簡單介紹一下如何安裝和簡單使用,為還不知道PowerShell Core on Ubuntu的同學們提供一點小小的入門幫助,謝謝大家支持~ PowerShell Core是由Mic ...
  • 匿名對象:就是沒有名字的對象 new student(); 匿名對象的應用場景: 1.僅僅調用一次對象中的方法 註意:調用多次的時候,不合適 匿名對象調用方法有什麼方法? 匿名對象調用完畢就是垃圾,可以被垃圾回收期回收。 2.匿名對象可以作為實際參數傳遞。 ...
  • 開發人員使用Jersey和CXF等工具可以方便地編寫java client,從而提供REST或SOAP服務;開發人員也可以基於Apache HC等http傳輸工具包編寫自己的java http client;而Feign的關註點在於簡化開發人員使用工具包的複雜度,以最少的代碼編寫代碼從而提供java... ...
  • 這一章中作者簡要的介紹了python數據模型,主要是python的一些特殊方法。比如__len__, __getitem__. 並用一個紙牌的程式來講解了這些方法 首先介紹下Tuple和nametuple的區別: Nametuple是類似於元組的數據類型。除了能夠用索引來訪問數據,還支持用方便的屬性 ...
  • 成員變數和局部變數的區別: 1.在類中的位置不同 成員變數:在類中,方法外 局部變數:在方法定義中或者方法聲明上 2.在記憶體中的位置不同: 成員變數:在堆記憶體中 局部變數:在棧記憶體中 3.生命周期不同: 成員變數:隨著對象的創建而存在,隨著對象的消失而消失 局部變數:隨著方法的調用而存在,隨著方法的 ...
  • 用通俗易懂、並且儘量短小精悍的正反例,介紹面向對象SOLID原則。大約15分鐘左右可以消化完成。 ...
  • 一、下載Spring的jar包 通過http://repo.spring.io/release/org/springframework/spring/地址下載最新的Spring的zip包,當然,如果你是在使用maven工程的話,可以不用下載Zip包,可以直接在maven工程的pom.xml文件中添加 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...