如图:在本地安装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&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 <br />\n \$status = $status<br />\n";
之后保存代码重新去刷新刚才的页面。
原来是没有/api/uc.php文件的权限,进入目录查看下:
apache没有权限,修改下权限:
chmod g+r+w+x -R api
修改后刷新下,发现通信成功:
查看另外一个应用的错误信息,发现错误如下:
原来是数据库连不上,查看后发现配置文件写错了,改好后通信就成功了。