我的网站是用discuz搭建的,但用户注册是没有找回密码这一项,请问怎么添加呢?

我的网站是用discuz搭建的,但用户注册是没有找回密码这一项,请问怎么添加呢?,第1张

打开template/default/member/login_simplehtm下的文件 当然 如果换了其他模板要去template下的模板文件夹中找{lang getpassword}找到这个就是找回密码的 看一下这个文件里有没有

powered by discuz ”建议不要修改,修改DZ会直接以侵权把您告上法庭。

找到模板下的headerhtml文件 在<title>中删除

在构建我的vita系统的过程中,发现管理员管理的便捷与系统安全隐患之间的矛盾

全站采用cookie验证,比如wordpress的验证就是基于cookie的,由于cookie的明文传输

在局域网内极易被截获,或者这个vita在我不发骚的情况下存在了XSS漏洞的话,cookie被人截获,

在这种情况下,等于站点被人xxx了

另一种情况就是利用session来进行管理员身份的认证,但是由于php天生对于session的处理机制的问题,不能长时间保存,利用数据库构建的session系统开销太大,在这种情况下,我就只好先研究先下大家是怎么做的

于是分析了Discuz!的登陆验证机制

每个Discuz!论坛都有一个特定的authkey也就是Discuz!程序中的$_DCACHE['settings']['authkey']并且与用户的浏览器特征值HTTP_USER_AGENT一起组成了discuz_auth_key这个变量如下代码:

commoneincphp文件大概130行左右

$discuz_auth_key = md5($_DCACHE['settings']['authkey']$_SERVER['HTTP_USER_AGENT']);

在Discuz!论坛用户登陆以后会有一个cookie,名称为cdb_auth(cdb_是你站点的名称,可以设置不能在configincphp 文件中设置),Discuz!论坛就靠这个来判断一个用户是否是登陆状态,在分析这个值的内容之前,我们看下他是如何生成的

list($discuz_pw, $discuz_secques, $discuz_uid) = empty($_DCOOKIE['auth']) array('', '', 0) : daddslashes(explode("\t", authcode($_DCOOKIE['auth'], 'DECODE')), 1);

解释一下,获得的客户端的cookie经过Discuz!的函数authcode解密以后会得到用户输入的用户名,密码,在authcode函数中 会用到刚刚提到的$discuz_auth_key这个值,在不知道$discuz_auth_key的情况下,基本上靠cookie里的值反解出用户名 密码的几率为0,同样的,在生成cdb_auth就是相逆的一个流程,先获得用户输入的用户名,密码,在验证正确之后,用authcode加密,写入 cookie,很简单吧

以上就是Discuz!普通用户的登陆验证过程,写的不是很详细,大概能看明白就行

操作步骤:

进入后台后,打开应用,搜索之后,安装应用时,提示请先输入安全密码

确定密码没错的情况下,某些个应用也是会出现这个问题的,没办法,只能通过忘记密码来换个密码了

重置安全密码需要对网站的归属进行验证,下载校验文件,

将下载的校验文件,通过FTP软件,上传到网站空间的安装目录

上传完成后,回到上一步的页面,点击 校验

验证成功后,记得把刚刚上传的addonresettxt文件删除,

输入新的安全密码,然后保存,这样安全密码就更新成功了

DABAN RP主题是一个优秀的主题,极致后台体验,无插件,集成会员系统
网站模板库 » 我的网站是用discuz搭建的,但用户注册是没有找回密码这一项,请问怎么添加呢?

0条评论

发表评论

提供最优质的资源集合

立即查看 了解详情