anf与现有系统的简单整合

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吸收掉错误,而无返回,你不一定要这么做。
None.gif          public   void  Register()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                User user 
= new User();
InBlock.gif                user.Username 
= Username;    
InBlock.gif                user.Password 
= Password;
InBlock.gif                user.Email 
= "Anonymous@Anonymous.com";
InBlock.gif                user.AccountStatus 
= UserAccountStatus.Approved;
InBlock.gif                user.IsAnonymous 
= false;
InBlock.gif
InBlock.gif                Users.Create(user, 
false);
ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }
  • 登录
    基本上都是复制粘贴过来的,注意最后的setcookie,这是同步登录的关键。
None.gif          public   void  Login()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                User userToLogin 
= new User();
InBlock.gif                userToLogin.Username 
= Username;
InBlock.gif                userToLogin.Password 
= Password;
InBlock.gif
InBlock.gif                LoginUserStatus loginStatus 
= Users.ValidUser(userToLogin);
InBlock.gif
InBlock.gif                
if (loginStatus == LoginUserStatus.Success)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
if (!Globals.GetSiteSettings().AllowLogin)
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        
bool allowed = false;
InBlock.gif
InBlock.gif                        
int userid = Users.FindUserByUsername(userToLogin.Username).UserID;
InBlock.gif                        ArrayList roles 
= Roles.GetRoles(userid);
InBlock.gif
InBlock.gif                        
foreach (Role role in roles)
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            
if (role.Name == "Site Administrators" || role.Name == "Global Administrators")
ExpandedSubBlockStart.gifContractedSubBlock.gif                            
dot.gif{
InBlock.gif                                allowed 
= true;
InBlock.gif                                
break;
ExpandedSubBlockEnd.gif                            }

ExpandedSubBlockEnd.gif                        }

InBlock.gif                        
if (!allowed)
ExpandedSubBlockStart.gifContractedSubBlock.gif                        
dot.gif{
InBlock.gif                            
return;
ExpandedSubBlockEnd.gif                        }

ExpandedSubBlockEnd.gif                    }

InBlock.gif
InBlock.gif                    set_Cookie(userToLogin.Username, 
"1");
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }
  • 修改密码
    这个假设是基于登录已经发生的,如果你的假设不是这样需要加入自己的判断。
None.gif          public   void  ChangePassword()
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                ForumContext forumContext 
= ForumContext.Current;
InBlock.gif                User user 
= forumContext.User;
InBlock.gif                
if (user != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    user.ChangePassword(Password, NewPassword);
ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }
  • 设置cookie
None.gif public   void  set_Cookie( string  Username,  string  Selet_item)
ExpandedBlockStart.gifContractedBlock.gif        
dot.gif {
InBlock.gif            
if(Selet_item == "0")
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                FormsAuthentication.SetAuthCookie(Username,
false);
ExpandedSubBlockEnd.gif            }

InBlock.gif            
else
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                ForumContext forumContext 
= ForumContext.Current;
InBlock.gif                FormsAuthentication.SetAuthCookie(Username,
true);
InBlock.gif                forumContext.Context.Response.Cookies[FormsAuthentication.FormsCookieName].Expires
=DateTime.Now.AddDays(System.Convert.ToInt32(Selet_item));
ExpandedSubBlockEnd.gif            }

ExpandedBlockEnd.gif        }

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

转载于:https://www.cnblogs.com/kyo1028/archive/2006/04/20/380144.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值