微信公众平台开发教程(八)Session处理问题

2019-05-26 03:25:28王旭

/// <summary>
  /// 操作过程
  /// </summary>
  enum OperationStage
  {
    /// <summary>
    /// 默认
    /// </summary>
    Default,
    /// <summary>
    /// 第一步
    /// </summary>
    First,
    /// <summary>
    /// 第二步
    /// </summary>
    Second,
    /// <summary>
    /// 第三步
    /// </summary>
    Third
  }

4、Session缓存项

缓存记录的项,这里面记录了操作类型、操作步骤以及会话对象。为了便于进行Session管理,还增加了最后访问时间,是否自动清除标识。

class SessionItem
  {
    /// <summary>
    /// 操作类型
    /// </summary>
    public Operation Oper { get; set; }
    /// <summary>
    /// 当前步骤
    /// </summary>
    public OperationStage Stage { get; set; }
    /// <summary>
    /// 数据对象
    /// </summary>
    public object Data { get; set; }
    /// <summary>
    /// 是否自动删除
    /// </summary>
    public bool AutoRemove
    {
      get;
      set;
    }
    /// <summary>
    /// 最后更新时间
    /// </summary>
    public DateTime UpdateTime { get; set; }
  }

二、就要在消息处理中,加入Session处理。

1、增加缓存项数据对象

这个对象,记录用户在会话过程中,录入的相关信息。也是作为业务处理数据提供对象。

class AuthSessionItem
  {
    /// <summary>
    /// 用户名
    /// </summary>
    public string FromUserName { get; set; }
    /// <summary>
    /// 账号
    /// </summary>
    public string Code { get; set; }
    /// <summary>
    /// 唯一标识
    /// </summary>
    public string ID { get; set; }
  }

 2、认证处理过程

1)开始进入认证,根据认证关键字进行标识,启动会话,并缓存相关数据

2)提示录入个人账号信息

3)微信用户录入个人账号,服务端记录账号信息,并提示录入员工卡号

4)微信用户录入卡号信息,服务端记录卡号信息,并调用具体的认证逻辑

5)用户认证通过,绑定微信OpenId,提示成功绑定信息,并清除会话。

在认证过程中,需要对用户录入信息进行合法性验证,而且在会话过程中,支持用户退出当前操作。

/// <summary>
    /// 认证用户信息
    /// </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))
      {
        //检查是否已经认证,业务组件验证
        if (UserManager.IsAuth(tm.FromUserName))
        {
          //如果已经认证,提示
          tm.Content = "您已经认证过了,无需再次认证!";          
        }
        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);

          //输入账号,并将数据和步骤,写入缓存
          tm.Content = "请输入您的个人账号";
        }

        response = ResponseText(tm);
        return false;
      }

      //从Session获取用户信息
      sessionItem = Session.Get(tm.FromUserName) as SessionItem;
      //如果会话存在,且当前操作为用户认证
      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退出认证请输入Exit。";
          response = ResponseText(tm); 
        }
        else if (sessionItem.Stage == OperationStage.Second)
        {
          string cardNum = null;
          if (!Common.TryConvertToCardNum(tm.Content, out cardNum))
          {            
            tm.Content = "员工卡号不合法,请重新输入。n退出认证请输入Exit。";
            response = ResponseText(tm);
            return false;
          }
          AuthSessionItem authSessionItem = sessionItem.Data as AuthSessionItem;
          if (authSessionItem != null)
          {
            authSessionItem.ID = cardNum;
          }
          //认证
          string message;
          if (UserManager.Authenticate(authSessionItem, out message))
          {
            tm.Content = "祝贺您,已经认证成功,可以使用通讯录的查询功能呢。";
            //清理缓存
            Session.Remove(tm.FromUserName);
            response = ResponseText(tm);
            return true;
          }
          else if (!string.IsNullOrEmpty(message))
          {
            tm.Content = message;
          }
          else
          {
            tm.Content = "您输入的信息有误。n重新认证请输入:Auth!";
          }
          //过程结束:清理Session
          Session.Remove(tm.FromUserName);
          response = ResponseText(tm);
          return false;
        }
      }

      return false;
    }