功杰宸斐 发表于 2024-10-7 16:26:45

Wordpress无法登陆终极解决方案

本文适合对象:安装后无法登陆后台,输入用户名和密码后仍然跳转到登陆页面,无法进入后台,无任何错误代码显示。如果你的问题是因为升级后无法登陆,且显示错误代码请参照上的解决方案
    下面这两段是我解决的整个过程,本人是个菜鸟,也对wordpress不熟悉,所以解决的比较可笑,走了不少弯路,废话较多,可跳过直接看后边的解决办法,如果有空也可看一下。
    ( 昨天晚上装的wordpress,由于是在学校里,晚上11点熄灯,我的笔记本也很快的消耗者电力,没办法学校校园网网速慢,不到熄灯上传如蜗牛一般,只能趁着熄灯后这段时间对网站更新内容,由于是新建的网站,各方面内容都要手动制作,太慢了,所以想建个博客,先把内容放到博客上再慢慢搞,决定装一个wordpress,由于本人是个菜鸟,对wordpress也不了解,下下来后就上传,上传到www目录下,花了40多分钟,然后很不幸的发现电池只剩了10分钟的电力,因为怕明天起来然后网速太慢,我毅然决定先装上再说,自动创建config一步一步还很顺利,但是到了最关键的一步,当安装到数据库时,突然电脑关机了,我心里拔凉拔凉的,不知道到底有没有装上,就上床睡了。
    第二天早上起来,准备登陆wordpress看一下,输入用户名和密码后发现网页又是跳回到登陆界面,试了好几次都是这样,我以为是用户名或密码错了,就先到邮箱里看,发现没错,又到数据库内看发现数据库内的密码与那个密码不一样,我我就试了试数据库内的密码,发现还是不行,我觉得这肯定是安装突然中断,数据库还没生成好引起的,就决定重新安装,安装时我还是自动生成config,安装到最后居然说我安装过了,先让我清理数据库,我就一个个把数据库内的删了然后还是自动生成config结果还是不行,让我很郁闷,我就开始在网上搜索解决办法,看了以后感觉应该是数据库名字的问题,还是手动写个config,于是就写了一个,再次安装,果然不再提示安装过,然后登陆,居然还是这种情况,我就郁闷了,我又想,这样安装的这么快,难道还是没有生成数据库,我到数据库看了看,发现的确生成了数据库,数据库没问题,我有搜索了一圈,想起来是不是因为我装在www目录下,登录时他又转到www外去了,于是检查了一下数据库中的siteurl和home发现果然时目录设置出了问题,改了目录后再次登陆,真是功夫不负有心人,后台终于出现在我面前,花了一天的时间终于把它搞定了。)
    下面是具体解决流程:
    1 首先打开phpadmin,从左边的表中选择xx_opition
    2 在xx_opition中进行查询,在查询框中输入
    SELECT * FROM `mn_options` WHERE `option_name` IN ('siteurl','home') LIMIT 0,30
    3查询后修改siteurl home的指向,如果你是安装在www目录下,而你绑定你的域名在wordpress文件夹上时,此时siteurl home一般是http:******/wordpress,将wordpress删除只剩下http:******
    4再次登陆,应该没问题了
    另在这做个小广告,本人博客刚开始建还没写什么,宣传一下我另外的站 bbs.wishhome.com.cn唯西网古典文化站,也是刚做的,
    如果以上不能解决,请联系我QQ或留言
    (另附上白板报中关于更新后无法登陆的解决办法)
    ( 我是如何解决Wordpress无法登陆问题的
    Published by wangpeiat 12:26 am under 乱炖
    前后花费了三个晚上,我终于解决了Wordpress升级后,用户名、密码都正确,却无法登陆的问题。为了让后来者不吃二遍苦,不受二茬罪,我把解决的详细过程与思路,记录如下。
    一、问题描述
    这一问题,有几种描述方式,为了让搜索引擎能够找到这篇文章,我把各种常用的叫法汇集如下:
    1、有以症状命名的,例如:wordpress无法登陆,密码正确、登录不了,锁到wordpress之外,可以访问、无法登录;
    2、有以成因命名的,例如:wordpress升级出错,wordpress2.6升级无法登陆……
    3、有以出错语句命名的,这种方式最多:
    1) Warning: Invalid argument supplied for foreach() ……
    2)capabilities.php on line 31
    3)Warning: Cannot modify header information - headers already sent by (output started at……
    4、一篇法国人写的著名的解决方案,是这样命名的:Invalid argument supplied for foreach() in wp-capabilities.php: Case Cracked!
    (需要指出的是,这篇文章虽然被搜索得很多,但极具有误导性,害了不少人,我认为完全在胡说八道!下文会谈及)
    5、有以痛苦感受命名的:天哪,我登陆不上博客了,救命啊,雪地翻跟头跪求……
    用这种命名方式搜索,田螺姑娘都没办法帮你。
    二、出错语句
    出错信息除了上面描述的语句之外,还有其他形式,试搜集如下:
    1、我的出错信息:
    Warning: Invalid argument supplied for foreach() in /homepages/23/d/htdocs/wp-includes/capabilities.php on line 31
    Warning: Cannot modify header information - headers already sent by (output started at /homepages/23/d/htdocs/wp-includes/capabilities.php:31) in /homepages/23/d/htdocs/wp-includes/pluggable.php on line 552
    Warning: Cannot modify header information - headers already sent by (output started at /homepages/23/d/htdocs/wp-includes/capabilities.php:31) in /homepages/23/d/htdocs/wp-includes/pluggable.php on line 689
    2、以下大同小异,但肯定有这一句:
    Warning: Invalid argument supplied for foreach() in /home/user/wp/wp-includes/capabilities.php on line 31
    三、出错诱因
    目前来看,这个问题大部分情况是发生在为wordpress升级时,不但从2.5升到wordpress2.6,也看到过从2.2或者更低版本升级,遇到这一情况的。
    也有案例显示,安装时就出现这一错误。这个非常罕见。
    四、出错原因
    我不懂技术,网上有各种说法,有说是uft-8编码转换出了问题,有人说陷入死循环。
    这些都不重要,重要的是解决办法,难道不是吗?
    五、修改字符编码法,或set names utf8法
    这种办法,网上最多。它提供的解决办法是:
    第一步:用phpMyadmin后台,把字符编码修改为utf-8。这里要注意,如果你用的是mySql4.0话,当你把字符修改成utf-8后,它下次还会显示gb2312,甭理它,其实已经改好了,我的经验是这样。
    还有人说,还应该设置数据库的collation为utf8_general_ci:因为在新的服务器中建立数据库时,没有指定其为utf-8,更没设定collation,所以需要先设定数据库的字符集。
    执行命令:
    alter database myblog
    character set utf8;
    然后再在操作或者数据库PhpMyAdmin的登陆页面中设定collation为utf8_general_ci。
    第二步:修改/wp-includes/wp-db.php这个文件。
    这一学派认为,毛病出在wp-db.php中,没有设定好utf-8为字符集,从而造成了一系列悲剧。因此,必须修改这个文件。这一学派又有下属三个分支流派:
    流派一:在$this-dbh = @mysql_connect($dbhost, $dbuser, $dbpassword);后面加上$this-query(set names utf8′); 注意英文标点。
    该学派认为,出错原因是wp-includes/capabilities.php里面$this-roles这个数组取到的是乱码。
    流派二:就是害人的法国人的那个方案,他认为应该在上述同意位置,加上这一语句:mysql_query(SET NAMES utf8′);,其实这是错误的!!
    流派三:还有人主张$this-query(set names utf8′);这个语句应该加到wp-db.php的另外一个位置;另外还要增加另外一处代码。我之所以,没有详细列出来,是因为这种办法根本无效。
    我试过以上三种办法,最后保留了流派一的办法。
    但我强烈怀疑,这种办法的有效性!!
    六、胡说八道法,又名检查wp_options表法,又又名wp_user_roles法
    这个办法是法国人发明的,他说,在phpMyadmin里,打开wp_options表,找到wp_user_roles一项,从中发现一个法语怪字符,Abonné,他认为正是这顶小帽子害得程序成为死循环,于是把它改成英文字符,于是立即神奇般地好了。
    这个法国人还说了一句阿基米德的名言:Eurêka! ,希腊语,我找到了!真是糟蹋先贤。
    实际上这个办法是最害人的。我照着把长达3公里的代码仔细检查,把所有中文都换成英文,结果依然故我。像这样被误导而浪费时间的不止我一个。
    七、个别成功法,又名清除cookies法
    有人骄傲地宣布,解决了wordpress2.6升级后无法登陆的问题,就是清除cookies。我试了,发现这个办法是无效的。
    但这启发了我,有时候你意想不到的办法,反而就是正解。
    八、有效办法,又名土耳其补丁法
    我在彻底绝望的时候,做了几件事:把wordpress2.6删除,换回了wp2.5。
    第二尝试数据库倒裤无果之后,我抱着试试看的办法,找到了这个帖子。
    这是土耳其人写的一个小补丁,他说只对2.3.X版本有效。但根据我的经验,后续版本应该也可以兼容。
    于是我下载了这个插件,
    解压后,将它放到wordpress安装根目录下。就是这副样子:(wp_user_)
    然后敲入上述网址:wp_user_
    满屏都是字符串。
    等尘埃落定,我不敢相信,我真的做到了,我又可以自由登陆我心爱的WORDPRESS了。)
页: [1]
查看完整版本: Wordpress无法登陆终极解决方案