ASP.NET网站与Discuz!NT论坛整合

1.引入5个DLL到项目中

分别是

using Discuz.Common;
using Discuz.Forum;
using Discuz.Config;
using Discuz.Entity;

using Discuz.Data;

 

2

 

   public class Discuz_NT
    {

        public static ArrayList Login(string username, string password, int question, string answer)
        {
            Discuz.Config.GeneralConfigInfo config = Discuz.Config.GeneralConfigs.GetConfig();
            OnlineUserInfo oluserinfo = OnlineUsers.UpdateInfo(config.Passwordkey, config.Onlinetimeout);
            int olid = oluserinfo.Olid;

            ArrayList result = new ArrayList();
            int uid = -1;
            //如果设置中Discuz!NT的密码模式为动网密码兼容模式(一般仅用于从动网数据转换来的论坛)
            if (config.Passwordmode == 1)
            {
                //如果后台设置了必须使用安全提问
                if (config.Secques == 1)
                {
                    uid = Users.CheckDvBbsPasswordAndSecques(username, password, question, answer);
                }
                else
                {
                    uid = Users.CheckDvBbsPassword(username, password);
                }
            }
            //如果设置中Discuz!NT的密码模式为一般模式
            else
            {
                //如果后台设置了必须使用安全提问
                if (config.Secques == 1)
                {
                    uid = Users.CheckPasswordAndSecques(username, password, true, question, answer);
                }
                else
                {
                    //最典型的用户验证方法
                    uid = Users.CheckPassword(username, password, true);
                }
            }
            //如果CheckPassword方法的返回值不为-1,则代表已经找到了相应的合法用户
            if (uid != -1)
            {
                result.Add(true);
                ShortUserInfo __userinfo = Users.GetShortUserInfo(uid);
                if (__userinfo.Groupid == 8)
                {
                    //这里添加代码提示"抱歉, 您的用户身份尚未得到验证"并return退出
                    //...
                    //
                    if (config.Regverify == 1)
                    {
                        result.Add("这里添加代码提示“请您到您的邮箱中点击激活链接来激活您的帐号”并return退出");
                    }

                    if (config.Regverify == 2)
                    {
                        result.Add("这里添加代码提示“您需要等待一些时间, 待系统管理员审核您的帐户后才可登录使用”并return退出");
                    }
                }
                else
                {

                    //删除之前的错误登录信息
                    LoginLogs.DeleteLoginLog(DNTRequest.GetIP());
                    //根据积分公式刷新用户总积分
                    UserCredits.UpdateUserCredits(uid);
                    //写入用户登录后的cookie
                    ForumUtils.WriteUserCookie(uid, Utils.StrToInt(DNTRequest.GetString("expires"), -1), config.Passwordkey, DNTRequest.GetInt("templateid", 0), DNTRequest.GetInt("loginmode", -1));
                    //更新用户最后动作,如不需要可不执行
                    OnlineUsers.UpdateAction(olid, UserAction.Login.ActionID, 0, config.Onlinetimeout);
                    //更新该用户最后访问时间
                    Users.UpdateUserLastvisit(uid, DNTRequest.GetIP());

                    result.Add("登录成功");
                }

            }
            else
            {
                result.Add(false);
                int errcount = LoginLogs.UpdateLoginLog(DNTRequest.GetIP(), true);
                if (errcount > 5)
                {
                    result.Add("这里添加代码提示“您已经输入密码5次错误, 请15分钟后再试”并return退出");
                }
                else
                {
                    result.Add("密码或安全提问第" + errcount.ToString() + "次错误, 您最多有5次机会重试");
                }
            }
            return result;
        }

        public static void Logout()
        {
            Discuz.Config.GeneralConfigInfo config = Discuz.Config.GeneralConfigs.GetConfig();
            OnlineUserInfo oluserinfo = OnlineUsers.UpdateInfo(config.Passwordkey, config.Onlinetimeout);
            int olid = oluserinfo.Olid;

            int uid = Convert.ToInt32(ForumUtils.GetCookie("userid"));
            Users.UpdateOnlineTime(uid);
            OnlineUsers.DeleteRows(olid);
            ForumUtils.ClearUserCookie();
        }

        /// <summary>
        /// 注册
        /// </summary>
        /// <param name="username"></param>
        /// <param name="password"></param>
        /// <param name="email"></param>
        /// <param name="question"></param>
        /// <param name="answer"></param>
        /// <returns></returns>
        public static bool Register(string username, string password, string email,int question,string answer)
        {
            GeneralConfigInfo config = GeneralConfigs.GetConfig();
            OnlineUserInfo oluserinfo = OnlineUsers.UpdateInfo(config.Passwordkey, config.Onlinetimeout);
            UserGroupInfo usergroupinfo = UserGroups.GetUserGroupInfo(oluserinfo.Groupid);

            //如果用户名符合注册规则, 则判断是否已存在
            if (Users.Exists(username))
            {
                //
                // 这里提示错误信息"用户名已经存在!"
                //
                return false;
            }

            UserInfo __userinfo = new UserInfo();
            __userinfo.Username = Utils.HtmlEncode(username);
            __userinfo.Nickname = "";
            __userinfo.Password = Utils.MD5(password);
            __userinfo.Secques = ForumUtils.GetUserSecques(question, answer);
            __userinfo.Gender = 0;
            __userinfo.Adminid = 0;
            __userinfo.Groupexpiry = 0;
            __userinfo.Extgroupids = "";
            __userinfo.Regip = DNTRequest.GetIP();
            __userinfo.Joindate = Utils.GetDateTime();
            __userinfo.Lastip = DNTRequest.GetIP();
            __userinfo.Lastvisit = Utils.GetDateTime();
            __userinfo.Lastactivity = Utils.GetDateTime();
            __userinfo.Lastpost = Utils.GetDateTime();
            __userinfo.Lastpostid = 0;
            __userinfo.Lastposttitle = "";
            __userinfo.Posts = 0;
            __userinfo.Digestposts = 0;
            __userinfo.Oltime = 0;
            __userinfo.Pageviews = 0;
            __userinfo.Credits = 0;
            __userinfo.Extcredits1 = Scoresets.GetScoreSet(1).Init;
            __userinfo.Extcredits2 = Scoresets.GetScoreSet(2).Init;
            __userinfo.Extcredits3 = Scoresets.GetScoreSet(3).Init;
            __userinfo.Extcredits4 = Scoresets.GetScoreSet(4).Init;
            __userinfo.Extcredits5 = Scoresets.GetScoreSet(5).Init;
            __userinfo.Extcredits6 = Scoresets.GetScoreSet(6).Init;
            __userinfo.Extcredits7 = Scoresets.GetScoreSet(7).Init;
            __userinfo.Extcredits8 = Scoresets.GetScoreSet(8).Init;
            __userinfo.Avatarshowid = 0;
            __userinfo.Email = email;
            __userinfo.Bday = tmpBday;
            __userinfo.Sigstatus = 1;

            if (__userinfo.Sigstatus != 0)
            {
                __userinfo.Sigstatus = 1;
            }
            __userinfo.Tpp = 0;
            __userinfo.Ppp = 0;
            __userinfo.Templateid = 1;
            __userinfo.Pmsound = 0;
            __userinfo.Showemail = 0;

            int receivepmsetting = 1;
            string receivesetting = "2,4";
            foreach (string rpms in receivesetting.Split(','))
            {
                if (rpms != string.Empty)
                {
                    int tmp = int.Parse(rpms);
                    receivepmsetting = receivepmsetting | tmp;
                }
            }

            if (config.Regadvance == 0)
            {
                receivepmsetting = 7;
            }

            __userinfo.Newsletter = (ReceivePMSettingType)receivepmsetting;
            __userinfo.Invisible = 0;
            __userinfo.Newpm = 0;
            __userinfo.Medals = "";
            if (config.Welcomemsg == 1)
            {
                __userinfo.Newpm = 1;
            }
            __userinfo.Accessmasks = 0;
            //
            __userinfo.Website = "";
            __userinfo.Icq = "";
            __userinfo.Qq = "";
            __userinfo.Yahoo = "";
            __userinfo.Msn = "";
            __userinfo.Skype = "";
            __userinfo.Location = "";
            if (usergroupinfo.Allowcstatus == 1)
            {
                __userinfo.Customstatus = "";
            }
            else
            {
                __userinfo.Customstatus = "";
            }
            __userinfo.Avatar = @"avatars\common\0.gif";
            __userinfo.Avatarwidth = 0;
            __userinfo.Avatarheight = 0;
            __userinfo.Bio = "";
            __userinfo.Signature = "";

            PostpramsInfo _postpramsinfo = new PostpramsInfo();
            _postpramsinfo.Usergroupid = usergroupid;
            _postpramsinfo.Attachimgpost = config.Attachimgpost;
            _postpramsinfo.Showattachmentpath = config.Showattachmentpath;
            _postpramsinfo.Hide = 0;
            _postpramsinfo.Price = 0;
            _postpramsinfo.Sdetail = __userinfo.Signature;
            _postpramsinfo.Smileyoff = 1;
            _postpramsinfo.Bbcodeoff = 1 - usergroupinfo.Allowsigbbcode;
            _postpramsinfo.Parseurloff = 1;
            _postpramsinfo.Showimages = usergroupinfo.Allowsigimgcode;
            _postpramsinfo.Allowhtml = 0;
            _postpramsinfo.Smiliesinfo = Smilies.GetSmiliesListWithInfo();
            _postpramsinfo.Customeditorbuttoninfo = Editors.GetCustomEditButtonListWithInfo();
            _postpramsinfo.Smiliesmax = config.Smiliesmax;

            __userinfo.Sightml = UBB.UBBToHTML(_postpramsinfo);

            //
            __userinfo.Authtime = Utils.GetDateTime();

            //邮箱激活链接验证
            if (config.Regverify == 1)
            {
                __userinfo.Authstr = ForumUtils.CreateAuthStr(20);
                __userinfo.Authflag = 1;
                __userinfo.Groupid = 8;
                SendEmail(tmpUsername, password.Trim(), email.Trim(), __userinfo.Authstr);
            }
            //系统管理员进行后台验证
            else if (config.Regverify == 2)
            {
                __userinfo.Authstr = "";
                __userinfo.Groupid = 8;
                __userinfo.Authflag = 1;
            }
            else
            {
                __userinfo.Authstr = "";
                __userinfo.Authflag = 0;
                __userinfo.Groupid = UserCredits.GetCreditsUserGroupID(0).Groupid;
            }
            __userinfo.Realname = "";
            __userinfo.Idcard = "";
            __userinfo.Mobile = "";
            __userinfo.Phone ="";

            int uid = Users.CreateUser(__userinfo);

            if (config.Welcomemsg == 1)
            {
                PrivateMessageInfo __privatemessageinfo = new PrivateMessageInfo();

                string curdatetime = Utils.GetDateTime();
                // 收件箱
                __privatemessageinfo.Message = config.Welcomemsgtxt;
                __privatemessageinfo.Subject = "欢迎您的加入! (请勿回复本信息)";
                __privatemessageinfo.Msgto = __userinfo.Username;
                __privatemessageinfo.Msgtoid = uid;
                __privatemessageinfo.Msgfrom = PrivateMessages.SystemUserName;
                __privatemessageinfo.Msgfromid = 0;
                __privatemessageinfo.New = 1;
                __privatemessageinfo.Postdatetime = curdatetime;
                __privatemessageinfo.Folder = 0;
                PrivateMessages.CreatePrivateMessage(__privatemessageinfo, 0);
            }

            if (config.Regverify == 0)
            {
                UserCredits.UpdateUserCredits(uid);
                ForumUtils.WriteUserCookie(uid, -1, config.Passwordkey);
                OnlineUsers.UpdateAction(olid, UserAction.Register.ActionID, 0, config.Onlinetimeout);


                Statistics.ReSetStatisticsCache();

                return true;
            }
            else
            {

                if (config.Regverify == 1)
                {
                    //这里添加代码提示“注册成功, 请您到您的邮箱中点击激活链接来激活您的帐号"并return退出
                    return true;
                }

                if (config.Regverify == 2)
                {
                    //这里添加代码提示“您注册成功, 但需要系统管理员审核您的帐户后才可登陆使用"并return退出
                    return true;
                }

            }

            return false;
        }

    }

 

 

3.如果想从www.domainname.xxx和bbs.domainname.XXX同步还得设置一下config\general.config
将 <CookieDomain/>改为<CookieDomain>domainname.XXX</CookieDomain>

 

转载于:https://www.cnblogs.com/chenbg2001/archive/2009/11/11/1601038.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Discuz!NT 2.5 是康盛创想(Comsenz)旗下的一款功能强大的基于 ASP.NET 平台的社区软件。基于先进的 .NET Framework,默认支持 SQLServer数据库,可扩展支持Access、MySQL等多种数据库,支持IIS5、IIS6、IIS7,安全高效、稳定易用,充分发挥 ASP.NET 特性,支持自由选择切换皮肤,支持多种其它论坛的数据转换。<br>Discuz!NT 2.5 强化论坛功能,提高速度和稳定性,负载能力有显著改善。提供包括商品交易、空间、相册等强大功能的插件包,供用户自由选择安装,体现出强大的伸缩扩展性。Discuz!NT 2.5继续传承Discuz!的优势,充分挖掘了ASP.NET平台的潜能,致力于为用户提供一个更加完善更加成熟稳定的ASP.NET社区软件。<br><br><br><br><br>Discuz!NT2.5新增六大创新:<br>创新一:支持最新Windows Server2008、IIS7、Silverlight 2.0 beta2 <br><br>创新二:新增商品交易插件,社区系统自带应用插件化<br><br>创新三:优化用户在线处理,提高负载能力,减少等待时间<br> <br>创新四:全新后台菜单模式,增加快速导航功能,更加方便管理<br><br>创新五:优化搜索引擎设置,页面加入更多有利于搜索引擎抓取的元素<br><br>创新六:简化模板复杂程度,加入了新的模板语法,方便二次开发 <br><br><br>Discuz!NT2.5七大亮点:<br>亮点一:成熟的辩论贴功能 用户可以对某一问题的不同观点发起辩论<br><br>亮点二:超级悬赏帖功能,在其他人的帮助下得到某种信息的悬赏功能<br><br>亮点三:新增标签即Tag功能,系统自动抓取与主题相关的关键词<br><br>亮点四:我的附件功能,方便用户更快找到上传过的附件<br> <br>亮点五:优化统计信息功能,论坛数据信息,一目了然<br><br>亮点六:广告信息强力屏蔽,系统后台设置了对新用户的信息过滤的功能<br><br>亮点七:聚合首页,论坛快速变成门户 加强了基于论坛内容调用的首页聚合功能<br>
论坛演示地址: http://netfocus.b13.cnwg.cn 论坛功能设计  论坛前台: 1. 用户注册、登陆、注销; 2. 版块导航:显示所有的版块分组和版块; 3. 帖子列表:显示当前版块下所有的帖子,可以区分置顶帖子、精华帖子、推荐帖子; 4. 帖子内容:显示帖子内容; 5. 帖子回复:显示帖子的回复列表; 6. 添加帖子:用户添加新帖; 7. 添加回复:用户添加回复; 8. 精华帖子列表:显示所有的精华帖子; 9. 推荐帖子列表:显示所有的推荐帖子; 10. 帖子管理:具有帖子管理权限的人对帖子进行管理; 11. 回复管理:具有帖子回复管理权限的人对帖子回复进行管理;  论坛后台: 1. 版块组管理:添加、删除、修改; 2. 版块管理:添加、删除、修改,添加或修改时通过下拉框选择版块组; 3. 版主管理:可以管理论坛中每个版块的版主,如添加、删除版主; 4. 用户管理:查看用户资料、删除用户、封锁用户、解锁用户、重置密码; 5. 角色管理:添加、删除、修改; 默认定义如下角色: 系统管理员、用户管理员、角色管理员、版块管理员、版主管理员、版主、所有者、注册用户、所有人;其中所有者指发帖人,回复人;另外系统管理员、注册用户、所有者、所有人是内置角色,不能修改或删除;下面分别对每种角色的含义进行说明: 1) 系统管理员:拥有论坛所有权限; 2) 用户管理员:拥有用户管理权限; 3) 角色管理员:拥有角色管理权限; 4) 版块管理员:拥有版块管理权限; 5) 版主管理员:拥有版主管理权限; 6) 版主:拥有所有论坛事务管理权限; 7) 所有者:拥有对自己发表的帖子或回复的内容进行修改的权限;(此角色可以考虑禁用,出于数据真实性考虑,因为任何人都要对他或她所说的言行负责,不允许随便修改); 8) 注册用户:拥有一部分论坛事务,如看帖,发帖,回帖,管理和自己相关的一些帖子; 9) 所有人:这个角色只是一个映射角色,任何登陆网站的人都自动拥有此角色;此角色可以表示匿名用户;仅拥有此角色的人一般只能看帖,不能做其他任何事情。当然如果愿意,我们也可以给它分配更多的权限,如发帖,回帖。如果这样,那就意味着运行匿名用户发帖或回帖了。 6. 用户角色管理:对任意一个用户的所属角色进行管理(包括添加和删除用户所属角色); 7. 角色权限管理:分为两类进行管理; 系统管理权限:用户管理、角色管理、版块管理、版主管理; 论坛事务管理权限:浏览帖子、发表帖子、编辑帖子、置顶帖子、设为推荐帖子、设为精华帖子、删除帖子、修改回复、删除回复; 因为权限分为两种,所以角色权限管理也可以采用两个界面实现。这两个界面的行就是所有角色,列就是当前权限类型下的所有权限点。 8. 头像设置:设置用户的头像; 9. 密码修改; 10. 我的帖子管理:有我发布的帖子,我回复的帖子; 另外,一个论坛可能还常常有星级评定,积分设置,界面管理,等等其他辅助功能。这些东西可以在日后慢慢补充。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值