android 发 HTTP 请求上传图片时,用网站地址发不同,只能用 IP 地址发(经 Nginx)

2015-03-25 09:17:44 +08:00
 GaryZ

android 实现上传图片到服务端,用到了httpmime这个包,发送复杂格式的数据到服务端,正常测试环境都没有问题,但是在正式环境上HTTP求情就发送不过去,后来检查如果把http请求的地址改成服务器IP地址就没问题,请问这是什么原因? 是android 的原因还是Nginx的原因? 如何解决?

3137 次点击
所在节点    程序员
18 条回复
jokester
2015-03-25 09:21:15 +08:00
did the request reached nginx? have you looked at the request?
ETiV
2015-03-25 09:23:31 +08:00
服务器在哪?域名是否备案?
GaryZ
2015-03-25 09:35:56 +08:00
@jokester yes.it is.

@ETiV 服务器就在隔壁,已备案,网站都已经上线了
ETiV
2015-03-25 09:44:26 +08:00
在本地用curl之类的模拟提交一次?

“发送不过去”的描述不是很准确,是断网后发不出去?还是域名解析不了发不出去?还是发出去了,服务器响应有问题?
lfzyx
2015-03-25 09:47:59 +08:00
看nginx 的日志
GaryZ
2015-03-25 09:49:46 +08:00
@ETiV 如果我用 域名发送请求,能到达Nginx,之后就没了。如果我用IP发请求,就会正常,啥问题都没有。
jokester
2015-03-25 09:51:29 +08:00
顶楼说"发送不过去"
下面又说请求到nginx了
找人帮忙至少把事情说清楚吧。。
GaryZ
2015-03-25 10:00:11 +08:00
@jokester 不好意思,描述的不太正确。见谅
aru
2015-03-25 10:05:39 +08:00
先试试在android里面用域名下载网站里面的一个图片
ETiV
2015-03-25 10:06:33 +08:00
那就看看nginx的log吧,都打开。

其实你自己会诊断问题,一般都不需要求助别人了~
virusdefender
2015-03-25 10:14:53 +08:00
这种问题应该好解决~先写个html或者js上传试试
thyrlian
2015-03-25 10:15:17 +08:00
用CharlesProxy或者Wireshark监听, 看你的Request Payload和Response Header/Body返回信息究竟如何.
ryd994
2015-03-25 11:40:04 +08:00
这是一个修复chunked支持的补丁,没有解释为什么用域名就不行啊?
GaryZ
2015-03-25 12:25:57 +08:00
@ryd994 错误码411 错误解释是(需要有效长度) 服务器不会接受包含无效内容长度标头字段的请求。也就是说这个版本的Nginx 不支持文件数据形式的HTTP请求吧
aheadlead
2015-03-25 14:12:53 +08:00
@icedx 来看看
ryd994
2015-03-25 15:01:29 +08:00
@GaryZ 对,因为不支持chunked encoding。问题是,为什么域名就不行?为什么用IP就行?除了Host头,其他在http协议上应该都一样。说明你没找到实际原因啊。为什么对IP没用chunked encoding?还是说你test case没覆盖?
GaryZ
2015-03-25 15:56:54 +08:00
@ryd994 根本原因的确不是特别明白,用IP可以是因为用IP发请求,没经过Nginx转发啊。对吧?
ryd994
2015-03-26 02:33:05 +08:00
@GaryZ 你是说你直接请求后端么?请求反代服务器的IP会怎么样?域名解析出来是哪个IP就往哪个IP发

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/179189

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX