Skip to content

WebApiClient QA

老九 edited this page Apr 23, 2018 · 12 revisions

1 需要使用using (HttpApiClient.Create())吗?

一般情况下,应该使用单例模式来创建HttpApiClient,也就是说HttpApiClient的实例需要保存起来,直接不再利用(比如程序退出了),因为HttpApiClient支持并发,有些接口是有cookie衔接的,再说了创建HttpApiClient是有一点点性能损耗的。

2 HttpApiClient.Create的T接口为什么要继承IDisposable接口?

Create方法在缺省HttpApiConfig参数的情况下,T类型接口继承了IDisposable,开发者才可以自主控制T接口实例的生命周期,如果Create方法创建HttpApiConfig参数,接口可以不用继承IDisposable。其实接口还可以继承IHttpApiClient,因为接口的HttpApiClient代理类本身就实现了IHttpApiClient接口。

3 HttpApiClient.Create的T可以继承其它T1等的Api接口吗?

可以,只有IHttpApiClient、IDisposable是特殊接口,继承的其它接口都当作Api接口。

4 使用[ProxyAttribute(host,port)]代理特性前,怎么验证代理的有效性?

可以构建一个HttpProxy类,使用ToValidator()方法得到ProxyValidator对象,ProxyValidator对象有Validate方法可以验证代理有效性。

5 为什么不支持将接口的返回类型声明为Task对象而必须为Task<>或ITask<>?

这个是设计的原因,不是技术原因,不管开发者关不关注返回值,Http在正常情况下必然有响应,如果你不关注结果的解析,应该声明为Task,不去解析HttpResponseMessage就行。

6 使用WebApiClient了,怎么下载文件?

你应该将接口返回类型声明为ITask,然后自己保存里面的流;或者使用ITask的SaveAs()扩展方法保存为文件。

Clone this wiki locally