微信公眾平臺開發(fā)教程(八)Session處理問題
在微信窗口,輸入的信息有限,我們需要將一些信息分多次請求。
比如:在進(jìn)行用戶綁定時(shí),我們需要輸入用戶的相關(guān)信息,比如:用戶名、密碼,或者姓名、電話號碼,服務(wù)端驗(yàn)證通過,即可將系統(tǒng)用戶與微信用戶綁定。
然后,此微信賬戶就有一定的功能權(quán)限了,可以查積分,消費(fèi)記錄等。服務(wù)號:招商銀行信用卡,就有很多功能。
微信客戶端無法緩存信息,而且輸入信息有限,需要進(jìn)行多次請求,在服務(wù)端保存當(dāng)前會話狀態(tài)。這就需要Session。
本文以用戶認(rèn)證,綁定賬號為例,來說明具體處理。
一、創(chuàng)建通用的Session處理機(jī)制。
為了更好的說明原理,便于擴(kuò)展,我們來自己設(shè)計(jì)Session。當(dāng)然,這里也可以使用System.Web.SessionState.HttpSessionState,這是Web常用的Session機(jī)制。
1、自定義Session
用于存儲會話片段以及相關(guān)數(shù)據(jù)。
class Session { /// <summary> /// 緩存hashtable /// </summary> private static Hashtable mDic = new Hashtable(); /// <summary> /// 添加 /// </summary> /// <param name="key">key</param> /// <param name="value">value</param> public static void Add(string key, object value) { mDic[key] = value; } /// <summary> /// 移除 /// </summary> /// <param name="key">key</param> public static void Remove(string key) { if (Contains(key)) { mDic.Remove(key); } } /// <summary> /// 設(shè)置值 /// </summary> /// <param name="key"></param> /// <param name="value"></param> public static void Set(string key, object value) { mDic[key] = value; } /// <summary> /// 獲取值 /// </summary> /// <param name="key"></param> /// <returns></returns> public static object Get(string key) { return mDic[key]; } /// <summary> /// 是否含有 /// </summary> /// <param name="key">key</param> /// <returns>bool</returns> public static bool Contains(string key) { return mDic.ContainsKey(key); } /// <summary> /// 清空所有項(xiàng) /// </summary> public static void Clear() { mDic.Clear(); } }
2、操作類型
記錄具體的操作類型,標(biāo)識當(dāng)前會話的具體操作
/// <summary> /// 操作類型 /// </summary> enum Operation { /// <summary> /// 認(rèn)證 /// </summary> Auth, /// <summary> /// 添加用戶 /// </summary> CreateUser }
3、操作過程枚舉
用于標(biāo)識當(dāng)前操作,處于哪一個階段,不同階段做不同的處理。
/// <summary> /// 操作過程 /// </summary> enum OperationStage { /// <summary> /// 默認(rèn) /// </summary> Default, /// <summary> /// 第一步 /// </summary> First, /// <summary> /// 第二步 /// </summary> Second, /// <summary> /// 第三步 /// </summary> Third }
4、Session緩存項(xiàng)
緩存記錄的項(xiàng),這里面記錄了操作類型、操作步驟以及會話對象。為了便于進(jìn)行Session管理,還增加了最后訪問時(shí)間,是否自動清除標(biāo)識。
class SessionItem { /// <summary> /// 操作類型 /// </summary> public Operation Oper { get; set; } /// <summary> /// 當(dāng)前步驟 /// </summary> public OperationStage Stage { get; set; } /// <summary> /// 數(shù)據(jù)對象 /// </summary> public object Data { get; set; } /// <summary> /// 是否自動刪除 /// </summary> public bool AutoRemove { get; set; } /// <summary> /// 最后更新時(shí)間 /// </summary> public DateTime UpdateTime { get; set; } }
二、就要在消息處理中,加入Session處理。
1、增加緩存項(xiàng)數(shù)據(jù)對象
這個對象,記錄用戶在會話過程中,錄入的相關(guān)信息。也是作為業(yè)務(wù)處理數(shù)據(jù)提供對象。
class AuthSessionItem { /// <summary> /// 用戶名 /// </summary> public string FromUserName { get; set; } /// <summary> /// 賬號 /// </summary> public string Code { get; set; } /// <summary> /// 唯一標(biāo)識 /// </summary> public string ID { get; set; } }
2、認(rèn)證處理過程
1)開始進(jìn)入認(rèn)證,根據(jù)認(rèn)證關(guān)鍵字進(jìn)行標(biāo)識,啟動會話,并緩存相關(guān)數(shù)據(jù)
2)提示錄入個人賬號信息
3)微信用戶錄入個人賬號,服務(wù)端記錄賬號信息,并提示錄入員工卡號
4)微信用戶錄入卡號信息,服務(wù)端記錄卡號信息,并調(diào)用具體的認(rèn)證邏輯
5)用戶認(rèn)證通過,綁定微信OpenId,提示成功綁定信息,并清除會話。
在認(rèn)證過程中,需要對用戶錄入信息進(jìn)行合法性驗(yàn)證,而且在會話過程中,支持用戶退出當(dāng)前操作。
/// <summary> /// 認(rèn)證用戶信息 /// </summary> /// <param name="tm"></param> /// <returns></returns> private bool Auth(TextMessage tm, ref string response) { SessionItem sessionItem = null; if (string.Equals(tm.Content, "Auth", StringComparison.OrdinalIgnoreCase)) { //檢查是否已經(jīng)認(rèn)證,業(yè)務(wù)組件驗(yàn)證 if (UserManager.IsAuth(tm.FromUserName)) { //如果已經(jīng)認(rèn)證,提示 tm.Content = "您已經(jīng)認(rèn)證過了,無需再次認(rèn)證!"; } else { AuthSessionItem authSessionItem = new AuthSessionItem(); authSessionItem.FromUserName = tm.FromUserName; sessionItem.Oper = Operation.Auth; sessionItem.Stage = OperationStage.First; sessionItem.Data = authSessionItem; Session.Set(tm.FromUserName, sessionItem); //輸入賬號,并將數(shù)據(jù)和步驟,寫入緩存 tm.Content = "請輸入您的個人賬號"; } response = ResponseText(tm); return false; } //從Session獲取用戶信息 sessionItem = Session.Get(tm.FromUserName) as SessionItem; //如果會話存在,且當(dāng)前操作為用戶認(rèn)證 if (sessionItem != null && sessionItem.Oper == Operation.Auth) { if (sessionItem.Stage == OperationStage.First) { tm.Content = tm.Content.Trim(); if (string.IsNullOrEmpty(tm.Content) || tm.Content.Length > 20) { tm.Content = "輸入的個人賬號不合法,請重新輸入。"; response = ResponseText(tm); return false; } AuthSessionItem authSessionItem = sessionItem.Data as AuthSessionItem; if (authSessionItem != null) { authSessionItem.Code = tm.Content; } //更新緩存 sessionItem.Stage = OperationStage.Second; Session.Set(tm.FromUserName, sessionItem); tm.Content = "請輸入您的員工卡號!\n退出認(rèn)證請輸入Exit。"; response = ResponseText(tm); } else if (sessionItem.Stage == OperationStage.Second) { string cardNum = null; if (!Common.TryConvertToCardNum(tm.Content, out cardNum)) { tm.Content = "員工卡號不合法,請重新輸入。\n退出認(rèn)證請輸入Exit。"; response = ResponseText(tm); return false; } AuthSessionItem authSessionItem = sessionItem.Data as AuthSessionItem; if (authSessionItem != null) { authSessionItem.ID = cardNum; } //認(rèn)證 string message; if (UserManager.Authenticate(authSessionItem, out message)) { tm.Content = "祝賀您,已經(jīng)認(rèn)證成功,可以使用通訊錄的查詢功能呢。"; //清理緩存 Session.Remove(tm.FromUserName); response = ResponseText(tm); return true; } else if (!string.IsNullOrEmpty(message)) { tm.Content = message; } else { tm.Content = "您輸入的信息有誤。\n重新認(rèn)證請輸入:Auth!"; } //過程結(jié)束:清理Session Session.Remove(tm.FromUserName); response = ResponseText(tm); return false; } } return false; }
3、退出會話,清理Session
在認(rèn)證過程中,用戶可以通過命令,強(qiáng)制退出當(dāng)前操作,在退出當(dāng)前操作時(shí),需要清理會話信息。
/// <summary> /// 退出,并清理Session /// </summary> /// <param name="tm"></param> /// <param name="response"></param> /// <returns></returns> private bool Exit(TextMessage tm, ref string response) { //退出 if (string.Equals(tm.Content, "Exit", StringComparison.OrdinalIgnoreCase)) { //清除Session Session.Remove(tm.FromUserName); tm.Content = "您已退出當(dāng)前操作,請執(zhí)行其他操作。"; response = ResponseText(tm); return true; } return false; }
三、用戶認(rèn)證通過,綁定微信賬戶
用戶認(rèn)證通過,并綁定微信OpenId,通過OpenId即可查詢通訊錄、查詢個人積分以及消費(fèi)記錄等操作了。用戶認(rèn)證是一個身份認(rèn)證過程,也是一個用戶綁定過程。用戶身份認(rèn)證通過,即可通過微信賬號查詢具體信息了。這時(shí)候業(yè)務(wù)層可以根據(jù)微信分配的OpenId直接查詢用戶相關(guān)信息。
四、后記
通過這種方法,公眾賬號,可以通過小小的文本輸入框,實(shí)現(xiàn)更多、更復(fù)雜的業(yè)務(wù)應(yīng)用。當(dāng)然,還是通過提供網(wǎng)頁來進(jìn)行信息錄入,更直觀便捷。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ASP.NET Core讀取Request.Body的正確方法
相信大家在使用ASP.NET Core進(jìn)行開發(fā)的時(shí)候,肯定會涉及到讀取Request.Body的場景,畢竟我們大部分的POST請求都是將數(shù)據(jù)存放到Http的Body當(dāng)中,本文就介紹一下ASP.NET Core讀取Request.Body,感興趣的可以了解一下2021-05-05ASP.NET中GridView、DataList、DataGrid三個數(shù)據(jù)控件foreach遍歷用法示例
這篇文章主要介紹了ASP.NET中GridView、DataList、DataGrid三個數(shù)據(jù)控件foreach遍歷用法,結(jié)合實(shí)例形式分析了GridView、DataList、DataGrid使用foreach及for語句進(jìn)行數(shù)據(jù)遍歷的具體使用方法,需要的朋友可以參考下2016-08-08TreeView創(chuàng)建IHierarchicalDataSource類型的數(shù)據(jù)源實(shí)現(xiàn)
為TreeView創(chuàng)建IHierarchicalDataSource類型的數(shù)據(jù)源實(shí)現(xiàn)2009-01-01Asp.net內(nèi)置對象之Server對象(概述及應(yīng)用)
Server對象提供對服務(wù)器上的方法和屬性的訪問以及進(jìn)行HTML編碼的功能,本文主要圍繞server對象介紹詳細(xì)功能及常用屬性和主要方法,感興趣的朋友可以了解下,或許對你學(xué)習(xí)server對象有所幫助2013-02-02asp.net 通過httpModule計(jì)算頁面的執(zhí)行時(shí)間
有時(shí)候我們想檢測一下網(wǎng)頁的執(zhí)行效率。記錄下開始請求時(shí)的時(shí)間和頁面執(zhí)行完畢后的時(shí)間點(diǎn),這段時(shí)間差就是頁面的執(zhí)行時(shí)間了。要實(shí)現(xiàn)這個功能,通過HttpModule來實(shí)現(xiàn)是最方便而且準(zhǔn)確的。2011-02-02