排查DZ升级后与UCenter通信失败的终极解决方案排查DZ升级后与UCenter通信失败的终极解决方案

如图:在本地安装discuz后发现通信失败:

审查元素通信失败四个字:

代码:

<td width="90">
<div id="status_1">
<img src="images/error.gif" border="0" class="statimg">
<span class="red">通信失败</span>
</div>
<script id="link_1" testlink="admin.php?m=app&amp;a=ping&inajax=1&url=http%3A%2F%2Fwww.mydiscuz.com&ip=127.0.0.1&appid=1&random=1032231015" src="admin.php?m=app&a=ping&inajax=1&url=http%3A%2F%2Fwww.mydiscuz.com&ip=127.0.0.1&appid=1&random=1032231015&sid=1b715zSrkN2F%2Bc3pyGJHGoBkkHjweVCgI%2F%2Fqp6hTtFO%2FLwdxQUAlXyrtWpKBfYGknm%2BuHEnWyOaYWQ"></script>
<script>apps[0] = '1';</script>
</td>

从上面的testlink右健点击进去的页面如下:

我们来看当前的url地址:

http://www.ucserver.com/admin.php?m=app&a=ping&inajax=1&url=http%3A%2F%2Fwww.mydiscuz.com&ip=127.0.0.1&appid=1&random=1032231015&sid=1b715zSrkN2F%2Bc3pyGJHGoBkkHjweVCgI%2F%2Fqp6hTtFO%2FLwdxQUAlXyrtWpKBfYGknm%2BuHEnWyOaYWQ

m=app 就代表着这个控制器原型是 app,因为是后台的访问,因此对应的就是 ucenter 目录下的 ./control/admin/app.php

a=ping 代表着执行的是控制器原型中的 onping 方法

注:这个如果想刨根问底的同学可以去看入口程序admin.php

好,有向前了一小步,我们打开 ./control/admin/app.php 文件,找到 onping 方法,源码如下:

function onping() {
$ip = getgpc('ip');
$url = getgpc('url');
$appid = intval(getgpc('appid'));
$app = $_ENV['app']->get_app_by_appid($appid);
$status = '';
if($app['extra']['apppath'] && @include $app['extra']['apppath'].'./api/'.$app['apifilename']) {
$uc_note = new uc_note();
$status = $uc_note->test($note['getdata'], $note['postdata']);
} else {
$this->load('note');
$url = $_ENV['note']->get_url_code('test', '', $appid);
$status = $_ENV['app']->test_api($url, $ip);
}
if($status == '1') {
echo 'document.getElementById(\'status_'.$appid.'\').innerHTML = "<img src=\'images/correct.gif\' border=\'0\' class=\'statimg\' \/><span class=\'green\'>'.$this->lang['app_connent_ok'].'</span>";testlink();';
} else {
echo 'document.getElementById(\'status_'.$appid.'\').innerHTML = "<img src=\'images/error.gif\' border=\'0\' class=\'statimg\' \/><span class=\'red\'>'.$this->lang['app_connent_false'].'</span>";testlink();';
}

}

我们可以看到这个$status 等于1的时候会输出通信成功,除此之外输出通信失败。 好,那我们直接输出这个 $status ,看看不等于1的时候他是个什么东东。 在if($status == ‘1’) 上面打印下$url和$status :

echo "\$url = $url \n \$status = $status\n";

之后保存代码重新去刷新刚才的页面。

原来是没有/api/uc.php文件的权限,进入目录查看下:

apache没有权限,修改下权限:

chmod g+r+w+x -R api

修改后刷新下,发现通信成功:

查看另外一个应用的错误信息,发现错误如下:

原来是数据库连不上,查看后发现配置文件写错了,改好后通信就成功了。

———————
原作者:iastro
来源:CSDN
原文链接:https://blog.csdn.net/iastro/article/details/52398813

这个办法可谓是程序升级以后通信错误的终极解决办法了!受到通信失败困扰的站长朋友们不妨试试!

未经允许不得转载:Sheepbar博客 » 排查DZ升级后与UCenter通信失败的终极解决方案

赞 (0) 打赏

评论 0

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

觉得文章有用就打赏一下文章作者

微信扫一扫打赏