您的位置:首页 > 其它

用新浪微博接口发送图片微博失败的原因

2012-10-31 23:48 537 查看
昨天项目开发时遇到一个发送图片微博失败的奇怪问题,在本机发送图片微博是好的,但是放到测试机就是无法发送,代码如下

<?php
include_once( 'app/config.php' );
include_once( 'app/inc/saetv2.ex.class.php' );
include_once( 'app/inc/RedisSession.php');
$redisSession=new RedisSession($redis);
$token=$redisSession->getObject("token");
$c = new SaeTClientV2( WB_AKEY , WB_SKEY , $token['access_token'] );
var_dump($infto = $c->upload("tesdfsssfst","http://www.test.com/192.168.60.103/2012080948f5e0b3-282d-0422-bb4c-6651d7caa6ff.jpg"));
?>

但是运行是无法发送成功:

array(3) { ["error"]=> string(50) "unsupported image type, only suport JPG, GIF, PNG!" ["error_code"]=> int(20005) ["request"]=> string(23) "/2/statuses/upload.json" }


要发送的图片在我的浏览器里是可以访问的,我查看upload的代码发现使用的是file_get_contents函数
于是我在代码里加了

echo file_get_contents("http://www.test.com/192.168.60.103/2012080948f5e0b3-282d-0422-bb4c-6651d7caa6ff.jpg");





奇怪的是我把url改为绝对路径,却是能够获取到图片

echo file_get_contents("/opt/htdocs/www.test.com/192.168.60.103/2012080948f5e0b3-282d-0422-bb4c-6651d7caa6ff.jpg");

于是我在服务器上测试发现这个域名是使用127.0.0.1,而我的机器上配置的hosts是192.168.60.5

[root@operation5 conf]# curl -kvL http://www.test.com * About to connect() to www.test.com port 80
* Trying 127.0.0.1... connected
* Connected to www.test.com (127.0.0.1) port 80
> GET / HTTP/1.1
> User-Agent: curl/7.15.5 (i686-redhat-linux-gnu) libcurl/7.15.5 OpenSSL/0.9.8b zlib/1.2.3 libidn/0.6.5
> Host: www.test.com
> Accept: */*


这时我开始怀疑:当访问的服务器ip不是192.168.60.5时会访问到另外一个网站的内容了,因为www.test.com没有使用Flea框架。
查看了一下apache配置,果然:

192.168.60.5:80 is a NameVirtualHost
default server 192.168.60.5 (/opt/httpd/conf/extra/vhost/_default.conf:1)
port 80 namevhost 192.168.60.5 (/opt/httpd/conf/extra/vhost/_default.conf:1)
port 80 namevhost www.test.com (/opt/httpd/conf/extra/vhost/www.test.com.conf:1)
192.168.60.5:82 www.test2.com (/opt/httpd/conf/extra/vhost/www.test2.com.conf:18)
192.168.60.5:443 www.test3.com (/opt/httpd/conf/extra/vhost/www.test3.com.conf:74)
wildcard NameVirtualHosts and _default_ servers:
*:80 www.test4.com(/opt/httpd/conf/extra/vhost/www.test4.com.conf:308)
Syntax OK


见最后一行是*:80,所以就出现配hosts:www.test.com 127.0.0.1时,访问www.test.com访问到的内容为www.test4.com的内容
把*:80改为192.168.60.5:80就好了
或者把所有的192.168.60.5:80都改为*:80;
所以是用*.80还是ip:80必须要统一否则出现莫名其妙的问题

end
本文出自 “一方有” 博客,请务必保留此出处http://yifangyou.blog.51cto.com/900206/1045826
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐