Three20 NetWork 是一个针对NSUrlConnection进行封装的一个强大的网络处理模块,并且实现了强大的缓存机制。
本文原创,转载请写:
1. 首先我们先看看 TTURLRequest 这个类, 允许你自定义http method, body and parameters, as well as natural response. processing using TTURLResponse objects.
#import <Foundation/Foundation.h>
// Network
#import "Three20Network/TTURLRequestCachePolicy.h"
// Core
#import "Three20Core/TTCorePreprocessorMacros.h" // For __TTDEPRECATED_METHOD
@protocol TTURLRequestDelegate;
@protocol TTURLResponse;
@interface TTURLRequest : NSObject {
NSString* _urlPath; //url路径
NSString* _httpMethod; //http方法
NSData* _httpBody; //http体
NSMutableDictionary* _parameters; //参数
NSMutableDictionary* _headers; //http头
NSString* _contentType; //内容类型
NSStringEncoding _charsetForMultipart; //字符集编码
NSMutableArray* _files; //上传多个文件
id<TTURLResponse> _response;
TTURLRequestCachePolicy _cachePolicy; //缓存代理
NSTimeInterval _cacheExpirationAge; //缓存实效时间,默认是1天
NSString* _cacheKey; //缓存key
NSDate* _timestamp;
NSInteger _totalBytesLoaded; //已经加载的字节数
NSInteger _totalBytesExpected; //预计下载的字节数
NSInteger _totalBytesDownloaded; //下载的总字节数
NSInteger _totalContentLength; //总的内容长度
id _userInfo; //用户信息
BOOL _isLoading; //是否正在加载
BOOL _shouldHandleCookies; //是否处理cooke
BOOL _respondedFromCache; //是否从缓存里面取
BOOL _filterPasswordLogging; //记录密码日志
NSMutableArray* _delegates;
}
/**
* 请求加载的url路径
*/
@property (nonatomic, copy) NSString* urlPath;
/**
同上,已经不再使用了,用urlPath代替
*/
@property (nonatomic, copy) NSString* URL __TTDEPRECATED_METHOD;
/**
* 请求的http 方法名字
* @example @"POST"
* @example @"GET"
* @example @"PUT"
* @默认 (t @"GET")
*/
@property (nonatomic, copy) NSString* httpMethod;
/* * 一个处理response data 并且可以解析和验证的对象, 下面几个是处理的类型, 其中TTURLXMLResponse需要添加一个扩展框架 extThree20XML
* @see TTURLDataResponse
* @see TTURLImageResponse
* @see TTURLXMLResponse
*/
@property (nonatomic, retain) id<TTURLResponse> response;
/**
* 请求发送的Http body
* 如果提供了,就会一直使用. 当你使用POST或put方法的时候 ,先确定下。
* 如果httpBody提供了,那么post或put data 会从parameters属性 里面生成,不会被使用
*/
@property (nonatomic, retain) NSData* httpBody;
/**
* 请求数据的内容类型 The content type of the data in the request.
* 如果没有提供,并且httpMethod是post或 put ,那么contentType 是@"multipart/form-data".
*/
@property (nonatomic, copy) NSString* contentType;
/**
* HTTP POST/PUT方法的参数
*/
@property (nonatomic, readonly) NSMutableDictionary* parameters;
/**
* 自定义HTTP headers.
*/
@property (nonatomic, readonly) NSMutableDictionary* headers;
/**
* @默认缓存: TTURLRequestCachePolicyDefault
*/
@property (nonatomic) TTURLRequestCachePolicy cachePolicy;
/**
* 设置response缓存数据的最长时间
*默认是TT_DEFAULT_CACHE_EXPIRATION_AGE (1 week)
*/
@property (nonatomic) NSTimeInterval cacheExpirationAge;
/**
* 如果没有cache key, 那么唯一的key是从request data生成的。
*如果请求是post或put,那么post或put参数也会使用cache key生成的。
*如果设置了cache key ,你可以覆盖默认的cache key,使用你自己的。
*/
@property (nonatomic, copy) NSString* cacheKey;
/**
* 一个虚拟的对象,用来标识请求的唯一对象标识
*生成TTUserInfo对象会在这里使用
* @see TTUserInfo
*/
@property (nonatomic, retain) id userInfo;
@property (nonatomic, retain) NSDate* timestamp;
/**
* 当前请求是否激活了
*/
@property (nonatomic) BOOL isLoading;
/**
* 请求是否使用默认的cookie处理
* @param YES if cookies should be sent with and set for this request;
* otherwise NO.
* @discussion The default is YES - 相反cookies are sent from and
* stored to the cookie manager by default.
* @default YES
*/
@property (nonatomic) BOOL shouldHandleCookies;
/**
* 请求已经加载的字节数
*/
@property (nonatomic) NSInteger totalBytesLoaded;
/**
* 请求预计要加载的字节数
*/
@property (nonatomic) NSInteger totalBytesExpected;
/**
*已经从服务器上下载的总字节数
*/
@property (nonatomic) NSInteger totalBytesDownloaded;
/**
* 请求的总内容长度
*/
@property (nonatomic) NSInteger totalContentLength;
/**
* 是否从缓存加载
* 前提是请求已经加载完成
*/
@property (nonatomic) BOOL respondedFromCache;
/**
名字为密码的参数是否要记录日志.
*/
@property (nonatomic, assign) BOOL filterPasswordLogging;
/**
* 当创建multipart/form-data 数据使用的字符集 *
* @默认是 NSUTF8StringEncoding
*/
@property (nonatomic) NSStringEncoding charsetForMultipart;
/**
* An array of non-retained objects that receive messages about the progress of the request.
*/
@property (nonatomic, readonly) NSMutableArray* delegates;
+ (TTURLRequest*)request;
+ (TTURLRequest*)requestWithURL:(NSString*)URL delegate:(id /*<TTURLRequestDelegate>*/)delegate;
- (id)initWithURL:(NSString*)URL delegate:(id /*<TTURLRequestDelegate>*/)delegate;
- (void)setValue:(NSString *)value forHTTPHeaderField:(NSString *)field;
/**
*添加一个文件,整个文件数据发送出去
*/
- (void)addFile:(NSData*)data mimeType:(NSString*)mimeType fileName:(NSString*)fileName;
/**
* 尝试发送一个请求
*如果请求可以通过缓存来处理,就是同步请求
* 否则这个就是异步请求。
* @return YES 如果请求从缓存加载的话,就是同步请求
*/
- (BOOL)send;
/**
* 尝试发送一个同步请求
*不管数据是从网络取还是从缓存取,都会使用同步请求
*/
- (BOOL)sendSynchronously;
/**
* 取消请求
*如果是多个相同的url请求,其他的不会取消
*/
- (void)cancel;
- (NSURLRequest*)createNSURLRequest;
@end
DEMO:
先创建一个TTURLRequest 对象 TTURLRequest *request = [TTURLRequest requestWithURL: kRequestURLPath delegate: self];
并实现TTURLRequestDelegate协议,
处理图片请求使用: TTURLImageResponse,TTURLImageResponse仅仅是response types里面的一个, 你也可以使用 TTURLDataResponse 和 TTURLXMLResponse(这个xmlResponse需要添加一个扩展框架 extThree20XML )
request.response = [[[TTURLImageResponse alloc] init] autorelease];
[request send]; //异步方式去请求
#pragma mark -
#pragma mark TTURLRequestDelegate
//开始请求
- (void)requestDidStartLoad:(TTURLRequest*)request {
[_requestButton setTitle:@"Loading..." forState:UIControlStateNormal];
}
//请求完成
- (void)requestDidFinishLoad:(TTURLRequest*)request {
TTURLImageResponse* imageResponse = (TTURLImageResponse*)request.response;
if (nil == _imageView) {
_imageView = [[UIImageView alloc] initWithFrame:CGRectZero];
[_scrollView addSubview:_imageView];
}
_imageView.image = imageResponse.image;
[_imageView sizeToFit];
_imageView.alpha = 0;
[UIView beginAnimations:nil context:nil];
[UIView setAnimationDuration:0.5];
_requestButton.alpha = 0;
_clearCacheButton.alpha = 0;
[_scrollView setContentSize:_imageView.frame.size];
_imageView.alpha = 1;
[UIView commitAnimations];
}
//请求错误处理
- (void)request:(TTURLRequest*)request didFailLoadWithError:(NSError*)error {
[_requestButton setTitle:@"Failed to load, try again." forState:UIControlStateNormal];
}