苏飞论坛

标题: 关于”远程服务器返回错误: (417) Expectation failed“的解决方法 [打印本页]

作者: 站长苏飞    时间: 2013-5-14 22:00
标题: 关于”远程服务器返回错误: (417) Expectation failed“的解决方法
这个问题还真有人问到,那我就写一下原因吧
我先来说一下这个问题可能出现在什么情况下,
如果你在使用的Httphelper类时,使用了代理 就有可能会报这个错误,这原因其实大家如果了解Http协议的话应该很容易就明白了。
我们来看看Http1.1协议中关于这个的说明吧。
  1. (100状态码(见10.1.1节)的目的在于允许客户端判定服务器是否愿意接受客户端发来的消息主体(基于请求头域)在客户端发送此请求消息主体前。 在有些情况下,如果服务器拒绝查看消息主体,这时客户端发送消息主体是不合适的或会降低效率。)
复制代码
就是说 ‍Expect:100-Continue的作用是,设定Client 和 Server在Post数据前需要进行 ‍“请求头域” 的数据匹配,相当于是握手。如果匹配则开始进行body 的内容,Post数据。否则,报错(417) Unkown。
也可以这样理解
允许客户端发request消息body之前先用request header试探一下server,看server要不要接收//request body,再决定要不要发request body。

不要急我们再来看看下面的一段
  1. (‍对HTTP/1.1代理服务器的要求:
  2. --- 若代理服务器接到一个请求,此请求包含值为"100-continue"的Expect请求头域,并且代理服务器可能知道下一站点的服务器遵循HTTP/1.1或更高版协议,或者不知道下一站点服务器的HTTP版本,那么它必须包含此Expect头域来转发此请求。
  3. --- 若代理服务器知道下一站点服务器版本是HTTP/1.0或更低,则它不能转发此请求,并且它必须以417(期望失败)状态响应。
  4. --- 代理服务器应当维护一个缓存,以记录最近访问下一站点服务器的HTTP版本号。
  5. --- 若接收到的请求来自于版本是HTTP/1.0(或更低)的客户端,并且此请求不含值为"100-continue"的Expect请求头域,那么代理服务器不能转发100(继续)响应。)
  6. 由于我们使用的是代理服务器,那个还有一种原因不能忽略,就是如果目标网页的HTTP的版本号为1.0或之前的版本,而代理服务器的本版为1.1或以上。这么这是,代理服务器将不会转发我们的Post请求,并报错‍(417) Unkown。
  7. 再看wireshark的包信息,其中明确可以看出,协议的版本号为HTTP1.1。这样,我们基本上可以确定‍(417) Unkown的原因:

  8. 握手失败,请求头域类型不匹配。
复制代码
其实关键就在的Http1.1限制了要先握手,我们这样想一下,如果我们选择不握手是不是就行了,
当然是可以的。
处理方法如下
可以直接在Http请求之前加上这么一句
[code=csharp] System.Net.ServicePointManager.Expect100Continue = false;[/code]
这句的意思就是不握手直接请求
其实我们还可以直接设置request的属性也是一样的,上面的方法太绝对了,一下就限制死了
[code=csharp]request.ServicePoint.Expect100Continue = false;[/code]
还有一个咱是在WebConfig里进行配置
[code=html]<configuration>
<system.net>
<settings>
           <servicePointManager expect100Continue="false" />
</settings>
</system.net>
</configuration>[/code]
其实 这个还有一个更明示的解释
就是当发送的数据超过1024时,是否寻询问接收多出的数据
当然我们直接选择False就是不询问了。
这个在我的类里面还暂时没有这样的方法
request.ServicePoint.Expect100Continue
去修改上面的属性,这个在下一个版本中我一定更新上,如果大家需要的话可以直接自己先添加一个属性。
先应下急
最后感谢用户cyberarmy提出的这个问题http://www.sufeinet.com/thread-3133-1-1.html


作者: semoon    时间: 2013-10-18 23:11
感谢分享!~
作者: Have_A_Dream    时间: 2014-9-10 20:02
本帖最后由 Have_A_Dream 于 2014-9-10 20:06 编辑

@站长苏飞 我现在做的这个网站post,也是报这个错,根据教程设置后依然如此

(, 下载次数: 494)