1、UCenter 通信失败 和 无法同步登陆的调试方法本帖最后由 redstone 于 2009-8-21 10:31 编辑 程序开发必不可少的要去调试。问题可能是多种多样的,所以需要我们自己能找到解决问题的方法。一、通信失败如何调试 如下图所示看到这个不要怕,其实问题远没有你想的那么复杂 既然是调试,就是刨根问底,就是顺藤摸瓜,那就先找个到藤注:本教程使用 Firefox 浏览器,这里不是给他 AD,是 Firefox 的一系列调试工具我用的比较熟练1、我们先看看“通信失败”这四个字是怎么来的?大家有没有感觉这个通信失败或者通信成功是在页面加载之后才显示出来的。对这个地方并不是页面直接输出的。
2、而是页面重新去加载 js 去判断之后显示的。我们来看这个页面的源代码。ie 下可以直接点击右键查看源文件,firefox 需要选择 本帧 -查看帧源代码。之后我们在源代码中找到刚才显示通信失败的那个标签。这个不难吧。如下图所示这个通信状态就是图中高亮的那个 js 处理的结果。看上去和正常的 js 调用不一样。别怕,看这个源码的开始那个 js 代码。 1. 2. var apps = new Array();3. var run = 0;4. function testlink() 5. if(appsrun) 6. $(status_ + appsrun).innerHTML = 正在连接.;
3、7. $(link_ + appsrun).src = $(link_ + appsrun).getAttribute(testlink) + 8. 9. run+;10. 11. window.onload = testlink;12. 复制代码明白了吧。2、既然“藤”找到了,那我们就开始“摸”吧 copy 这段代码直接通过浏览器访问。这下明白那个通信失败四个字就来源于此了吧。呵呵。但是还是不知道为啥失败啊?别急,还没有摸到瓜,我不喊停你就继续摸啊。接下来就要在 uc 的代码中设置几个断点,其实就是 echo 之后 die。我们来看当前的 url 地址。 1. http:/ $url = g
4、etgpc(url);4. $appid = intval(getgpc(appid);5. $app = $_ENVapp-get_app_by_appid($appid);6. $status = ;7. if($appextraapppath 9. $status = $uc_note-test($notegetdata, $notepostdata);10. else 11. $this-load(note);12. $url = $_ENVnote-get_url_code(test, , $appid);13. $status = $_ENVapp-test_api($url, $
5、ip);14. 15. if($status = 1) 16. echo document.getElementById(status_.$appid.).innerHTML = “.$this-langapp_connent_ok.“;testlink();17. else 18. echo document.getElementById(status_.$appid.).innerHTML = “.$this-langapp_connent_false.“;testlink();19. 20.21. 复制代码这个代码我就不一一解释了。用点心,仔细一点都能看明白。我们可以看到这个$status 等于 1 的时候会输出通信成功,除此之外输出通信失败。好,那我们直接输出这个 $status ,看看不等于 1 的时候他是个什么东东。在 1. if($status = 1) 复制代码前面添加一行代码 1. echo “$url = $url n $status = $statusn“;die(haha);复制代码好的,断点也设置了,之后保存代码重新去刷新刚才的页面。3、终于快摸到“瓜”了,有点小兴奋,原来调试也不难吧。 刷新页面后看到这样的东东哦。原来是我的这个应用的访问地址弄错了。4、摸到瓜了吧,接下来对症下药是不是很简单了。记得去掉刚才的调试代码