C#中的HttpWebRequest类介绍
提供 webrequest 类的 http 特定的实现。
继承层次结构 system.object → system.marshalbyrefobject → system.net.webrequest → system.net.httpwebrequest
。
命名空间:system.net
; 程序集:system
(在 system.dll 中)
c#语法:
[serializableattribute]
public class httpwebrequest : webrequest, iserializable
httpwebrequest 类型公开以下成员。
1、构造函数
名称 | 说明 |
---|---|
httpwebrequest() | 已过时。初始化 httpwebrequest 类的新实例。 |
httpwebrequest(serializationinfo, streamingcontext) | 已过时。从 serializationinfo和 streamingcontext 类的指定实例初始化 httpwebrequest 类的新实例。 |
2、属性
名称 | 说明 |
---|---|
accept | 获取或设置 accept http 标头的值。 |
address | 获取实际响应请求的 internet 资源的统一资源标识符 (uri)。 |
allowautoredirect | 获取或设置一个值,该值指示请求是否应跟随重定向响应。 |
allowreadstreambuffering | 获取或设置一个值,该值指示是否对从 internet 资源接收的数据进行缓冲处理。 |
allowwritestreambuffering | 获取或设置一个值,该值指示是否对发送到 internet 资源的数据进行缓冲处理。 |
authenticationlevel | 获取或设置用于此请求的身份验证和模拟的级别。 (继承自 webrequest。) |
automaticdecompression | 获取或设置所使用的解压缩类型。 |
cachepolicy | 获取或设置此请求的缓存策略。 (继承自 webrequest。) |
clientcertificates | 获取或设置与此请求关联的安全证书集合。 |
connection | 获取或设置 connection http 标头的值。 |
connectiongroupname | 获取或设置请求的连接组的名称。 (重写 webrequest.connectiongroupname。) |
contentlength | 获取或设置 content-lengthhttp 标头。 (重写 webrequest.contentlength。) |
contenttype | 获取或设置 content-type http 标头的值。 (重写 webrequest.contenttype。) |
continuedelegate | 获取或设置当从 internet 资源接收到 http 100 持续响应时调用的委托方法。 |
continuetimeout | 获取或设置在接收到来自服务器的 100 次连续响应之前要等待的超时(以毫秒为单位)。 |
cookiecontainer | 获取或设置与此请求关联的 cookie。 |
creatorinstance | 已过时。当在子类中重写时,获取从 iwebrequestcreate 类派生的工厂对象,该类用于创建为生成对指定 uri 的请求而实例化的 webrequest。 (继承自 webrequest。) |
credentials | 获取或设置请求的身份验证信息。 (重写 webrequest.credentials。) |
date | 获取或设置要在 http 请求中使用的 date http 标头值。 |
defaultcachepolicy | 获取或设置此请求的默认缓存策略。 |
defaultmaximumerrorresponselength | 获取或设置 http 错误响应的默认最大长度。 |
defaultmaximumresponseheaderslength | 获取或设置 maximumresponseheaderslength 属性的默认值。 |
expect | 获取或设置 expect http 标头的值。 |
haveresponse | 获取一个值,该值指示是否收到了来自 internet 资源的响应。 |
headers | 指定构成 http 标头的名称/值对的集合。 (重写 webrequest.headers。) |
host | 获取或设置要在 http 请求中独立于请求 uri 使用的 host 标头值。 |
ifmodifiedsince | 获取或设置 if-modified-since http 标头的值。 |
impersonationlevel | 获取或设置当前请求的模拟级别。 (继承自 webrequest。) |
keepalive | 获取或设置一个值,该值指示是否与 internet 资源建立持久性连接。 |
maximumautomaticredirections | 获取或设置请求将跟随的重定向的最大数目。 |
maximumresponseheaderslength | 获取或设置响应标题允许的最大长度。 |
mediatype | 获取或设置请求的媒体类型。 |
method | 获取或设置请求的方法。 (重写 webrequest.method。) |
pipelined | 获取或设置一个值,该值指示是否通过管线将请求传输到 internet 资源。 |
preauthenticate | 获取或设置一个值,该值指示是否随请求发送一个身份验证标头。 (重写 webrequest.preauthenticate。) |
protocolversion | 获取或设置用于请求的 http 版本。 |
proxy | 获取或设置请求的代理信息。 (重写 webrequest.proxy。) |
readwritetimeout | 获取或设置写入或读取流时的超时(以毫秒为单位)。 |
referer | 获取或设置 referer http 标头的值。 |
requesturi | 获取请求的原始统一资源标识符 (uri)。 (重写 webrequest.requesturi。) |
sendchunked | 获取或设置一个值,该值指示是否将数据分段发送到 internet 资源。 |
servercertificatevalidationcallback | 获取或设置用于验证服务器证书的回调函数。 |
servicepoint | 获取用于请求的服务点。 |
supportscookiecontainer | 获取一个值,该值指示请求是否为 cookiecontainer 提供支持。 |
timeout | 获取或设置 getresponse 和 getrequeststream 方法的超时值(以毫秒为单位)。 (重写 webrequest.timeout。) |
transferencoding | 获取或设置 transfer-encoding http 标头的值。 |
unsafeauthenticatedconnectionsharing | 获取或设置一个值,该值指示是否允许经过高速 ntlm 身份验证的连接共享。 |
usedefaultcredentials | 获取或设置一个 boolean 值,该值控制默认凭据是否随请求一起发送。 (重写 webrequest.usedefaultcredentials。) |
useragent | 获取或设置 user-agent http 标头的值。 |
3、方法
名称 | 说明 |
---|---|
abort | 取消对 internet 资源的请求。 (重写 webrequest.abort()。) |
addrange(int32) | 向请求添加从请求数据的开始处或结束处的特定范围的字节范围标头。 |
addrange(int64) | 向请求添加从请求数据的开始处或结束处的特定范围的字节范围标头。 |
addrange(int32, int32) | 向请求添加指定范围的字节范围标头。 |
addrange(int64, int64) | 向请求添加指定范围的字节范围标头。 |
addrange(string, int32) | 向请求添加从请求数据的开始处或结束处计算的特定范围的 range 标头。 |
addrange(string, int64) | 向请求添加从请求数据的开始处或结束处计算的特定范围的 range 标头。 |
addrange(string, int32, int32) | 向请求添加指定范围的范围标头。 |
addrange(string, int64, int64) | 向请求添加指定范围的范围标头。 |
begingetrequeststream | 开始对用来写入数据的 stream 对象的异步请求。 (重写 webrequest.begingetrequeststream(asynccallback, object)。) |
begingetresponse | 开始对 internet 资源的异步请求。 (重写 webrequest.begingetresponse(asynccallback, object)。) |
createobjref | 创建一个对象,该对象包含生成用于与远程对象进行通信的代理所需的全部相关信息。 (继承自 marshalbyrefobject。) |
endgetrequeststream(iasyncresult) | 结束对用于写入数据的 stream 对象的异步请求。 (重写 webrequest.endgetrequeststream(iasyncresult)。) |
endgetrequeststream(iasyncresult,transportcontext) | 结束对用于写入数据的 stream 对象的异步请求,并输出与该流关联的 transportcontext。 |
endgetresponse | 结束对 internet 资源的异步请求。 (重写 webrequest.endgetresponse(iasyncresult)。) |
equals(object) | 确定指定的对象是否等于当前对象。 (继承自 object。) |
finalize | 允许对象在“垃圾回收”回收之前尝试释放资源并执行其他清理操作。 (继承自 object。) |
gethashcode | 作为默认哈希函数。 (继承自 object。) |
getlifetimeservice | 检索控制此实例的生存期策略的当前生存期服务对象。 (继承自 marshalbyrefobject。) |
getobjectdata | 基础结构。使用序列化目标对象所需的数据填充 serializationinfo。 (重写 webrequest.getobjectdata(serializationinfo, streamingcontext)。) |
getrequeststream() | 获取用于写入请求数据的 stream 对象。 (重写 webrequest.getrequeststream()。) |
getrequeststream(transportcontext) | 获取用于写入请求数据的 stream 对象,并输出与该流关联的 transportcontext。 |
getrequeststreamasync | 当在子类中被重写时,将用于写入数据的 stream 作为异步操作返回到 internet 资源。 (继承自 webrequest。) |
getresponse | 返回来自 internet 资源的响应。 (重写 webrequest.getresponse()。) |
getresponseasync | 当在子类中被重写时,将作为异步操作返回对 internet 请求的响应。 (继承自 webrequest。) |
gettype | 获取当前实例的 type。 (继承自 object。) |
initializelifetimeservice | 获取控制此实例的生存期策略的生存期服务对象。 (继承自 marshalbyrefobject。) |
memberwiseclone() | 创建当前 object 的浅表副本。 (继承自 object。) |
memberwiseclone(boolean) | 创建当前 marshalbyrefobject 对象的浅表副本。 (继承自 marshalbyrefobject。) |
tostring | 返回表示当前对象的字符串。 (继承自 object。) |
4、显示接口实现
名称 | 说明 |
---|---|
iserializable.getobjectdata | 基础结构。使用将目标对象序列化所需的数据填充 serializationinfo。 |
5、备注
httpwebrequest类对webrequest中定义的属性和方法提供支持,也对使用户能够直接与使用 http 的服务器交互的附加属性和方法提供支持。
不要使用httpwebrequest 构造函数。使用 webrequest.create方法初始化新的 httpwebrequest 对象。如果统一资源标识符 (uri) 的方案是 http:// 或 https://,则 create 返回 httpwebrequest 对象。
getresponse方法向requesturi属性中指定的资源发出同步请求并返回包含该响应的httpwebresponse。可以使用 begingetresponse 和 endgetresponse 方法对资源发出异步请求。
当要向资源发送数据时,getrequeststream 方法返回用于发送数据的 stream 对象。begingetrequeststream和endgetrequeststream方法提供对发送数据流的异步访问。
对于使用 httpwebrequest 的客户端验证身份,客户端证书必须安装在当前用户的“我的证书”存储区中。
如果在访问资源时发生错误,则 httpwebrequest 类将引发 webexception。webexception.status 属性包含指示错误源的 webexceptionstatus 值。 当 webexception.status 为 webexceptionstatus.protocolerror 时,response 属性包含从资源接收的 httpwebresponse。
httpwebrequest将发送到 internet 资源的公共 http 标头值公开为属性,由方法或系统设置;下表包含完整列表。可以将 headers 属性中的其他标头设置为名称/值对。注意,服务器和缓存在请求期间可能会更改或添加标头。
下表列出了由属性或方法设置或由系统设置的 http 标头。
header |
设置方 |
---|---|
accept |
由 accept 属性设置。 |
connection |
由 connection 属性和 keepalive 属性设置。 |
content-length |
由 contentlength 属性设置。 |
content-type |
由 contenttype 属性设置。 |
expect |
由 expect 属性设置。 |
日期 |
由系统设置为当前日期。 |
主机 |
由系统设置为当前主机信息。 |
if-modified-since |
由 ifmodifiedsince 属性设置。 |
范围 |
由 addrange 方法设置。 |
referer |
由 referer 属性设置。 |
transfer-encoding |
由 transferencoding 属性设置(sendchunked 属性必须为 true)。 |
user-agent |
由 useragent 属性设置。 |
说明 |
---|
httpwebrequest 自动注册。 使用以 http:// 或 https:// 开头的 uri 之前,不需要调用 registerprefix 方法来注册 system.net.httpwebrequest。 |
本地计算机或应用程序配置文件可能指定使用默认代理。 如果指定了 proxy 属性,则 proxy 属性中的代理设置会重写本地计算机或应用程序配置文件,并且 httpwebrequest 实例将实用指定的代理设置。 如果配置文件中未指定代理并且未指定 proxy 属性,则 httpwebrequest 类使用从本地计算机上的 internet explorer 中继承的代理设置。 如果 internet explorer 中没有代理设置,请求会直接发送到服务器。
httpwebrequest 类分析从 internet explorer 继承的且包含通配符的代理忽略列表时会与 internet explorer 直接分析忽略列表不同。 例如,httpwebrequest 类将来自 internet explorer 的其中包含“nt*”的忽略列表分析为正则表达式“nt.$”。 此行为不同于 internet explorer 的本机行为。 因此 url“http://intxxxxx”将忽略使用 httpwebrequest 类的代理,但它不会忽略使用 internet explorer 的代理。
说明 |
---|
framework 在创建 ssl 会话时缓存这些会话,如果可能,还尝试对新请求重用缓存的会话。 尝试重用 ssl 会话时,该框架将使用 clientcertificates 的第一个元素(如果有);如果 clientcertificates 为空,则将尝试重用匿名会话。 |
说明 |
---|
为安全起见,默认情况下禁用 cookie。 如果您希望使用 cookie,请使用 cookiecontainer 属性启用 cookie。 |
示例
下面的代码示例为 uri http://www.contoso.com/. 创建 httpwebrequest。
httpwebrequest myreq = (httpwebrequest)webrequest.create("http://www.contoso.com/");
到此这篇关于c#中的httpwebrequest类介绍的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 使用MDC实现日志链路跟踪