ASP.NET Forums与现有系统整合方案示例

  Asp.Net Forums以下简称ANF,版本2.0,本文系数流水帐,只是记录了一下今的工作,没啥技术含量。

  已有系统已经有自己的一套用户系统,需要挂接ANF,要求在已有系统用户注册,登录,修改密码时,在ANF中也做出相应反映。不要求ANF的用户变化影响已有系统,只是单向同步。

  在尽量少动已有代码的情况下找一种简单的方式来完成整合。之前看了宝玉的CnForums和已有系统的整合方案,最后偷懒决定在已有系统上述动作结束后将用户相关信息和操作类型附加在url后面传给一个新建页来处理在ANF中执行相关操作。

  这新建页暂且叫bridge.aspx 当然要建在ANF的项目中该using的都using了,负责接收用户名密码等信息然后执行相应的ANF操作。

  注册

  注册很简单,我的Username和Password是自己包装的属性,从Request中获取信息,我们系统没有Email就随便添一个,接下来要给AccountStatus设置为通过,IsAnonymous关掉。Users.Create中那个bool参数代表是否给用户发送注册成功提示的邮件,我没邮件当然关掉。

  注意我在所有的地方都catch吸收掉错误,而无返回,你不一定要这么做。

public void Register()
{
  try
  {
   User user = new User();
   user.Username = Username;
   user.Password = Password;
   user.Email = "Anonymous@Anonymous.com";
   user.AccountStatus = UserAccountStatus.Approved;
   user.IsAnonymous = false;
   Users.Create(user, false);
  }
  catch
  {
  }
}

  登录

  基本上都是复制粘贴过来的,注意最后的setcookie,这是同步登录的关键。

public void Login()
{
  try
  {
   User userToLogin = new User();
   userToLogin.Username = Username;
   userToLogin.Password = Password;

   LoginUserStatus loginStatus = Users.ValidUser(userToLogin);

   if (loginStatus == LoginUserStatus.Success)
   {
    if (!Globals.GetSiteSettings().AllowLogin)
    {
     bool allowed = false;

     int userid = Users.FindUserByUsername(userToLogin.Username).UserID;
     ArrayList roles = Roles.GetRoles(userid);

     foreach (Role role in roles)
     {
      if (role.Name == "Site Administrators" || role.Name == "Global Administrators")
      {
       allowed = true;
       break;
      }
     }
     if (!allowed)
     {
      return;
     }
    }
    set_Cookie(userToLogin.Username, "1");
   }
  }
  catch
  {
  }
}

  修改密码

  这个假设是基于登录已经发生的,如果你的假设不是这样需要加入自己的判断。

public void ChangePassword()
{
  try
  {
   ForumContext forumContext = ForumContext.Current;
   User user = forumContext.User;
   if (user != null)
   {
    user.ChangePassword(Password, NewPassword);
   }
  }
  catch
  {
  }
}

  设置cookie

public void set_Cookie(string Username, string Selet_item)
{
  if(Selet_item == "0")
  {
   FormsAuthentication.SetAuthCookie(Username,false);
  }
  else
  {
   ForumContext forumContext = ForumContext.Current;
   FormsAuthentication.SetAuthCookie(Username,true);
   forumContext.Context.Response.Cookies[FormsAuthentication.FormsCookieName].Expires=DateTime.
       _Now.AddDays(System.Convert.ToInt32(Selet_item));
  }
}

  最后在已有系统的注册,登录,修改的最后Response.Redirect这页就ok,不喜欢Redirect,Server.Transfer,xmlhttp都行,看你需要的展现了。还有一点很关键,就是要加密了你传输的字符串,要不明文就……※¥※×%※× ,要是嫌还不安全就用ip判断一下谁可以访问这页!

转自:http://tech.163.com/05/0714/11/1OKB18F700091589.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值