1.新建一个网络请求工具类,负责整个项目中所有的Http网络请求
提示:同步请求会卡住线程,发送网络请求应该使用异步请求(这意味着类方法不能有返回值)
2.工具类的实现

YYHttpTool.h文件

复制代码
1 //
2 // YYHttpTool.h
3 //网络请求工具类,负责整个项目中所有的Http网络请求
4
5 #import
6
7 @interface YYHttpTool : NSObject
8 /**
9 * 发送一个GET请求
10 *
11 * @param url 请求路径
12 * @param params 请求参数
13 * @param success 请求成功后的回调(请将请求成功后想做的事情写到这个block中)
14 * @param failure 请求失败后的回调(请将请求失败后想做的事情写到这个block中)
15 */
16 + (void)get:(NSString *)url params:(NSDictionary *)params success:(void(^)(id responseObj))success failure:(void(^)(NSError *error))failure;
17
18 /**
19 * 发送一个POST请求
20 *
21 * @param url 请求路径
22 * @param params 请求参数
23 * @param success 请求成功后的回调(请将请求成功后想做的事情写到这个block中)
24 * @param failure 请求失败后的回调(请将请求失败后想做的事情写到这个block中)
25 */
26 + (void)post:(NSString *)url params:(NSDictionary *)params success:(void(^)(id responseObj))success failure:(void(^)(NSError *error))failure;
27 @end
复制代码
YYHttpTool.m文件

复制代码
1 //
2 // YYHttpTool.m
3 //
4
5 #import "YYHttpTool.h"
6 #import "AFNetworking.h"
7 @implementation YYHttpTool
8 +(void)get:(NSString *)url params:(NSDictionary *)params success:(void (^)(id))success failure:(void (^)(NSError *))failure
9 {
10 //1.获得请求管理者
11 AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
12
13 //3.发送Get请求
14 [mgr GET:url parameters:params success:^(AFHTTPRequestOperation *operation, NSDictionary*responseObj) {
15 if (success) {
16 success(responseObj);
17 }
18 } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
19 if (failure) {
20 failure(error);
21 }
22 }];
23 }
24
25 +(void)post:(NSString *)url params:(NSDictionary *)params success:(void (^)(id))success failure:(void (^)(NSError *))failure
26 {
27 //1.获得请求管理者
28 AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
29
30 //2.发送Post请求
31 [mgr POST:url parameters:params success:^(AFHTTPRequestOperation *operation, NSDictionary*responseObj) {
32 if (success) {
33 success(responseObj);
34 }
35 } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
36 if (failure) {
37 failure(error);
38 }
39 }];
40
41 }
42 @end
复制代码
3.在项目中用到AFN框架的地方使用工具类进行替换

YYHomeTableViewController.m文件

复制代码
1 //
2 // YYHomeTableViewController.m
3 //
4
5 #import "YYHomeTableViewController.h"
6 #import "YYOneViewController.h"
7 #import "YYTitleButton.h"
8 #import "YYPopMenu.h"
9 #import "YYAccountModel.h"
10 #import "YYAccountTool.h"
11 //#import "AFNetworking.h"
12 #import "UIImageView+WebCache.h"
13 #import "YYUserModel.h"
14 #import "YYStatusModel.h"
15 #import "MJExtension.h"
16 #import "YYloadStatusesFooter.h"
17 #import "YYHttpTool.h"
18
19 @interface YYHomeTableViewController ()
20 @property(nonatomic,assign)BOOL down;
21 @property(nonatomic,strong)NSMutableArray *statuses;
22 @property(nonatomic,strong)YYloadStatusesFooter *footer;
23 @property(nonatomic,strong) YYTitleButton *titleButton;
24 @end
25
26 @implementation YYHomeTableViewController
27
28 #pragma mark- 懒加载
29 -(NSMutableArray *)statuses
30 {
31 if (_statuses==nil) {
32 _statuses=[NSMutableArray array];
33 }
34 return _statuses;
35 }
36 - (void)viewDidLoad
37 {
38 [super viewDidLoad];
39
40 //设置导航栏内容
41 [self setupNavBar];
42
43 //集成刷新控件
44 [self setupRefresh];
45
46 //设置用户的昵称为标题
47 //先显示首页标题,延迟两秒之后变换成用户昵称
48 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
49 [self setupUserInfo];
50 });
51 }
52
53 /**
54 *设置用户的昵称为标题
55 */
56 -(void)setupUserInfo
57 {
58 // //1.获得请求管理者
59 // AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
60 //
61 // //2.封装请求参数
62 // NSMutableDictionary *params=[NSMutableDictionary dictionary];
63 // params[@"access_token"] =[YYAccountTool accountModel].access_token;
64 // params[@"uid"]=[YYAccountTool accountModel].uid;
65 //
66 // //3.发送Get请求
67 // [mgr GET:@"https://api.weibo.com/2/users/show.json" parameters:params success:^(AFHTTPRequestOperation *operation, NSDictionary*userDict) {
68 //
69 // //字典转模型
70 // YYUserModel *user=[YYUserModel objectWithKeyValues:userDict];
71 //
72 // //设置标题
73 // [self.titleButton setTitle:user.name forState:UIControlStateNormal];
74 // // 存储账号信息(需要先拿到账号)
75 // YYAccountModel *account=[YYAccountTool accountModel];
76 // account.name=user.name;
77 // //存储
78 // [YYAccountTool save:account];
79 //
80 // } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
81 //
82 // }];
83
84 //1.封装请求参数
85 NSMutableDictionary *params=[NSMutableDictionary dictionary];
86 params[@"access_token"] =[YYAccountTool accountModel].access_token;
87 params[@"uid"]=[YYAccountTool accountModel].uid;
88
89 //2.发送网络请求
90 [YYHttpTool get:@"https://api.weibo.com/2/users/show.json" params:params success:^(id responseObj) {
91 //字典转模型
92 YYUserModel *user=[YYUserModel objectWithKeyValues:responseObj];
93 //设置标题
94 [self.titleButton setTitle:user.name forState:UIControlStateNormal];
95 // 存储账号信息(需要先拿到账号)
96 YYAccountModel *account=[YYAccountTool accountModel];
97 account.name=user.name;
98 //存储
99 [YYAccountTool save:account];
100 } failure:^(NSError *error) {
101 YYLog(@"请求失败");
102 }];
103 }
104
105 //集成刷新控件
106 -(void)setupRefresh
107 {
108 // 1.添加下拉刷新控件
109 UIRefreshControl *refreshControl = [[UIRefreshControl alloc] init];
110 [self.tableView addSubview:refreshControl];
111
112 //2.监听状态
113 [refreshControl addTarget:self action:(@selector(refreshControlStateChange:)) forControlEvents:UIControlEventValueChanged];
114
115 //3.让刷新控件自动进入到刷新状态
116 [refreshControl beginRefreshing];
117
118 //4.手动调用方法,加载数据
119 //模拟网络延迟,延迟2.0秒
120 dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
121 [self refreshControlStateChange:refreshControl];
122 });
123
124 //5.上拉刷新数据
125 YYloadStatusesFooter *footer=[YYloadStatusesFooter loadFooter];
126 self.tableView.tableFooterView=footer;
127 self.footer=footer;
128 }
129
130 /**
131 * 当下拉刷新控件进入刷新状态(转圈圈)的时候会自动调用
132 */
133 -(void)refreshControlStateChange:(UIRefreshControl *)refreshControl
134 {
135 //1.封装请求参数
136 NSMutableDictionary *params=[NSMutableDictionary dictionary];
137 params[@"access_token"] =[YYAccountTool accountModel].access_token;
138 //取出当前微博模型中的第一条数据,获取第一条数据的id
139 YYStatusModel *firstStatus=[self.statuses firstObject];
140 if (firstStatus) {
141 params[@"since_id"]=firstStatus.idstr;
142 }
143
144 //2.发送网络请求
145 [YYHttpTool get:@"https://api.weibo.com/2/statuses/home_timeline.json" params:params success:^(id responseObj) {
146
147 // 微博字典 -- 数组
148 NSArray *statusDictArray = responseObj[@"statuses"];
149 //微博字典数组---》微博模型数组
150 NSArray *newStatuses =[YYStatusModel objectArrayWithKeyValuesArray:statusDictArray];
151
152 //把新数据添加到旧数据的前面
153 NSRange range=NSMakeRange(0, newStatuses.count);
154 NSIndexSet *indexSet=[NSIndexSet indexSetWithIndexesInRange:range];
155 [self.statuses insertObjects:newStatuses atIndexes:indexSet];
156 YYLog(@"刷新了--%d条新数据",newStatuses.count);
157
158 //重新刷新表格
159 [self.tableView reloadData];
160 //让刷新控件停止刷新(回复默认的状态)
161 [refreshControl endRefreshing];
162 [self showNewStatusesCount:newStatuses.count];
163
164 } failure:^(NSError *error) {
165
166 YYLog(@"请求失败");
167 //让刷新控件停止刷新(回复默认的状态)
168 [refreshControl endRefreshing];
169 }];
170 }
171
172 /**
173 * 加载更多的微博数据
174 */
175 - (void)loadMoreStatuses
176 {
177 // 1.封装请求参数
178 NSMutableDictionary *params = [NSMutableDictionary dictionary];
179 params[@"access_token"] = [YYAccountTool accountModel].access_token;
180 YYStatusModel *lastStatus = [self.statuses lastObject];
181 if (lastStatus) {
182 params[@"max_id"] = @([lastStatus.idstr longLongValue] - 1);
183 }
184
185 //2.发送网络请求
186 [YYHttpTool get:@"https://api.weibo.com/2/statuses/home_timeline.json" params:params success:^(id responseObj) {
187 // 微博字典数组
188 NSArray *statusDictArray = responseObj[@"statuses"];
189 // 微博字典数组 ---> 微博模型数组
190 NSArray *newStatuses = [YYStatusModel objectArrayWithKeyValuesArray:statusDictArray];
191
192 // 将新数据插入到旧数据的最后面
193 [self.statuses addObjectsFromArray:newStatuses];
194
195 // 重新刷新表格
196 [self.tableView reloadData];
197
198 // 让刷新控件停止刷新(恢复默认的状态)
199 [self.footer endRefreshing];
200
201 } failure:^(NSError *error) {
202 YYLog(@"请求失败--%@", error);
203 // 让刷新控件停止刷新(恢复默认的状态)
204 [self.footer endRefreshing];
205 }];
206 }
207
208 /**
209 * 提示用户最新的微博数量
210 *
211 * @param count 最新的微博数量
212 */
213 -(void)showNewStatusesCount:(int)count
214 {
215 //1.创建一个label
216 UILabel *label=[[UILabel alloc]init];
217
218 //2.设置label的文字
219 if (count) {
220 label.text=[NSString stringWithFormat:@"共有%d条新的微博数据",count];
221 }else
222 {
223 label.text=@"没有最新的微博数据";
224 }
225
226 //3.设置label的背景和对其等属性
227 label.backgroundColor=[UIColor colorWithPatternImage:[UIImage imageWithName:@"timeline_new_status_background"]];
228 label.textAlignment=UITextAlignmentCenter;
229 label.textColor=[UIColor whiteColor];
230
231 //4.设置label的frame
232 label.x=0;
233 label.width=self.view.width;
234 label.height=35;
235 // label.y=64-label.height;
236 label.y=self.navigationController.navigationBar.height+20-label.height;
237
238 //5.把lable添加到导航控制器的View上
239 // [self.navigationController.view addSubview:label];
240 //把label添加到导航控制器上,显示在导航栏的下面
241 [self.navigationController.view insertSubview:label belowSubview:self.navigationController.navigationBar];
242
243 //6.设置动画效果
244 CGFloat duration=0.75;
245 //设置提示条的透明度
246 label.alpha=0.0;
247 [UIView animateWithDuration:duration animations:^{
248 //往下移动一个label的高度
249 label.transform=CGAffineTransformMakeTranslation(0, label.height);
250 label.alpha=1.0;
251 } completion:^(BOOL finished) {//向下移动完毕
252
253 //延迟delay秒的时间后,在执行动画
254 CGFloat delay=0.5;
255
256 [UIView animateKeyframesWithDuration:duration delay:delay options:UIViewAnimationOptionCurveEaseOut animations:^{
257
258 //恢复到原来的位置
259 label.transform=CGAffineTransformIdentity;
260 label.alpha=0.0;
261
262 } completion:^(BOOL finished) {
263
264 //删除控件
265 [label removeFromSuperview];
266 }];
267 }];
268 }
269
270 /**
271 UIViewAnimationOptionCurveEaseInOut = 0
16
17 @end
18
19 @implementation YYOAuthViewController
20
21 - (void)viewDidLoad
22 {
23 [super viewDidLoad];
24
25 //1.创建UIWebView
26 UIWebView *webView=[[UIWebView alloc]init];
27 webView.frame=self.view.bounds;
28 [self.view addSubview:webView];
29
30
31 //2.加载登陆界面
32 NSString *urlStr=[NSString stringWithFormat:@"https://api.weibo.com/oauth2/authorize?client_id=%@&redirect_uri=%@",YYAppKey,YYRedirectURI];
33 NSURL *url=[NSURL URLWithString:urlStr];
34 NSURLRequest *request=[[NSURLRequest alloc]initWithURL:url];
35 [webView loadRequest:request];
36
37 //3.设置代理
38 webView.delegate=self;
39 }
40
41 #pragma mark-UIWebViewDelegate
42 /**
43 * UIWebView开始加载资源的时候调用(开始发送请求)
44 */
45 -(void)webViewDidStartLoad:(UIWebView *)webView
46 {
47 [MBProgressHUD showMessage:@"正在努力加载中···"];
48 }
49
50 /**
51 * UIWebView加载完毕的时候调用(请求结束)
52 */
53 -(void)webViewDidFinishLoad:(UIWebView *)webView
54 {
55 [MBProgressHUD hideHUD];
56 }
57
58 /**
59 * UIWebView加载失败的时候调用(请求失败)
60 */
61 -(void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error
62 {
63 [MBProgressHUD hideHUD];
64 }
65
66 /**
67 * UIWebView每当发送一个请求之前,都会先调用这个代理方法(询问代理允不允许加载这个请求)
68 * @param request 即将发送的请求
69 * @return YES允许加载,NO不允许加载
70 */
71 -(BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType
72 {
73 //1.获得请求地址
74 NSString *urlStr=request.URL.absoluteString;
75 // NSLog(@"%@",urlStr);
76
77 //2.判断url是否为回调地址
78 //urlStr在字符串中的范围
79 //设置从等号位置开始,不用再额外的找位置
80 NSString *redirectURI=[NSString stringWithFormat:@"%@?code=",YYRedirectURI];
81 NSRange range=[urlStr rangeOfString:redirectURI];
82 //判断是否为回调地址
83 if (range.location!=NSNotFound) {//是回调地址
84 //截取授权成功后的请求标记
85 int from=range.location+range.length;
86 NSString *code=[urlStr substringFromIndex:from];
87 // YYLog(@"%@--%@--",urlStr,code);
88
89 //根据code获得一个accessToken
90 [self accessTokenWithCode:code];
91
92 //禁止加载回调页面,拿到想要的东西就好了。
93 return NO;
94 }
95 return YES;
96 }
97 /**
98 * 根据code获得一个accessToken(发送一个Post请求)
99 * @param code 授权成功后的请求标记
100 */
101 -(void)accessTokenWithCode:(NSString *)code
102 {
103 //1.封装请求参数
104 NSMutableDictionary *params=[NSMutableDictionary dictionary];
105 params[@"client_id"] =YYAppKey;
106 params[@"client_secret"] =YYAppSecret;
107 params[@"grant_type"] =@"authorization_code";
108 params[@"code"] =code;
109 params[@"redirect_uri"] =YYRedirectURI;
110
111 //2.发送网络请求
112 [YYHttpTool post:@"https://api.weibo.com/oauth2/access_token" params:params success:^(id responseObj) {
113 //隐藏遮罩
114 [MBProgressHUD hideHUD];
115
116 //字典转模型
117 YYAccountModel *accountmodel=[YYAccountModel accountModelWithDcit:responseObj];
118 //存储账号模型
119 [YYAccountTool save:accountmodel];
120
121 //3.2切换控制器
122 [YYControllerTool chooseRootViewController];
123
124 YYLog(@"请求成功");
125
126 } failure:^(NSError *error) {
127 //隐藏遮罩
128 [MBProgressHUD hideHUD];
129 YYLog(@"请求失败");
130 }];
131 }
132 @end
复制代码
发微博控制器中的处理(说明:发送带图片的微博暂时未做处理)

YYComposeViewController.m文件

复制代码
1 //
2 // YYComposeViewController.m
3 //
4
5 #import "YYComposeViewController.h"
6 #import "YYTextView.h"
7 #import "YYComposeToolBar.h"
8 #import "YYComposePhotosView.h"
9 #import "YYAccountModel.h"
10 #import "YYAccountTool.h"
11 //#import "AFNetworking.h"
12 #import "MBProgressHUD+MJ.h"
13 #import "YYHttpTool.h"
14
15 @interface YYComposeViewController ()
16 @property(nonatomic,weak)YYTextView *textView;
17 @property(nonatomic,weak)YYComposeToolBar *toolBar;
18 @property(nonatomic,weak)YYComposePhotosView *photoView;
19 @end
20
21 @implementation YYComposeViewController
22
23 #pragma mark-初始化方法
24 - (void)viewDidLoad
25 {
26 [super viewDidLoad];
27
28 //设置导航栏
29 [self setupNavBar];
30
31 //添加子控件
32 [self setupTextView];
33
34 //添加工具条
35 [self setupToolbar];
36
37 //添加photoView
38 [self setupPhotoView];
39
40 //写图片代码,把五张图片写入到相册中保存
41 for (int i=0; i formData) {
212 //#warning 目前新浪提供的发微博接口只能上传一张图片
213 // //取出图片
214 // UIImage *image=[self.photoView.images firstObject];
215 // //把图片写成NSData
216 // NSData *data=UIImageJPEGRepresentation(image, 1.0);
217 // //拼接文件参数
218 // [formData appendPartWithFileData:data name:@"pic" fileName:@"status.jpg" mimeType:@"image/jpeg"];
219 //
220 // } success:^(AFHTTPRequestOperation *operation, id responseObject) {
221 // [MBProgressHUD showSuccess:@"发表成功"];
222 // } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
223 // [MBProgressHUD showError:@"发表失败"];
224 // }];
225 }
226
227 /**
228 * 发送不带图片的微博
229 */
230 -(void)sendStatusWithoutImage
231 {
232 //
233 // //1.获得请求管理者
234 // AFHTTPRequestOperationManager *mgr = [AFHTTPRequestOperationManager manager];
235 //
236 // //2.封装请求参数
237 // NSMutableDictionary *params=[NSMutableDictionary dictionary];
238 // params[@"access_token"] =[YYAccountTool accountModel].access_token;
239 // params[@"status"]=self.textView.text;
240 //
241 // //3.发送POST请求
242 // [mgr POST:@"https://api.weibo.com/2/statuses/update.json" parameters:params success:^(AFHTTPRequestOperation *operation, NSDictionary*statusDict) {
243 // [MBProgressHUD showSuccess:@"发表成功"];
244 // } failure:^(AFHTTPRequestOperation *operation, NSError *error) {
245 // [MBProgressHUD showError:@"发表失败"];
246 // }];
247 //
248 // //4.关闭发送微博界面
249 //// [self dismissViewControllerAnimated:YES completion:nil];
250
251 //1.封装请求参数
252 NSMutableDictionary *params=[NSMutableDictionary dictionary];
253 params[@"access_token"] =[YYAccountTool accountModel].access_token;
254 params[@"status"]=self.textView.text;
255
256 //2.发送网络请求
257 [YYHttpTool post:@"https://api.weibo.com/2/statuses/update.json" params:params success:^(id responseObj) {
258 [MBProgressHUD showSuccess:@"发表成功"];
259 } failure:^(NSError *error) {
260 [MBProgressHUD showError:@"发表失败"];
261 }];
262 }
263 -(void)cancel
264 {
265 [self dismissViewControllerAnimated:YES completion:nil];
266 // self.textView.text=@"测试";
267 }
268
269
270 #pragma mark-YYComposeToolBarDelegate
271 -(void)composeTool:(YYComposeToolBar *)toolbar didClickedButton:(YYComposeToolbarButtonType)buttonType
272 {
273 switch (buttonType) {
274 case YYComposeToolbarButtonTypeCamera://照相机
275 [self openCamera];
276 break;
277
278 case YYComposeToolbarButtonTypePicture://相册
279 [self openAlbum];
280 break;
281
282 case YYComposeToolbarButtonTypeEmotion://表情
283 [self openEmotion];
284 break;
285
286 case YYComposeToolbarButtonTypeMention://提到
287 YYLog(@"提到");
288 break;
289
290 case YYComposeToolbarButtonTypeTrend://话题
291 YYLog(@"打开话题");
292 break;
293
294 default:
295 break;
296 }
297 }
298
299 /**
300 * 打开照相机
301 */
302 -(void)openCamera
303 {
304 //如果不能用,则直接返回
305 if (![UIImagePickerController isSourceTypeAvailable:UIImagePickerControllerSourceTypeCamera]) return;
306
307 UIImagePickerController *ipc=[[UIImagePickerController alloc]init];
308 ipc.sourceType=UIImagePickerControllerSourceTypeCamera;
309 ipc.delegate=self;
310 [self presentViewController:ipc animated:YES completion:nil];
311
312 }
313 /**
314 * 打开相册
315 */
316 -(void)openAlbum
317 {
318 //如果不能用,则直接返回
319 if (![UIImagePickerController isSourceTypeAvailable:UIImagePickerControllerSourceTypePhotoLibrary]) return;
320
321 UIImagePickerController *ipc=[[UIImagePickerController alloc]init];
322 ipc.sourceType=UIImagePickerControllerSourceTypePhotoLibrary;
323 ipc.delegate=self;
324 [self presentViewController:ipc animated:YES completion:nil];
325 }
326 /**
327 * 打开表情
328 */
329 -(void)openEmotion
330 {
331
332 }
333
334 #pragma mark-UIImagePickerControllerDelegate
335 -(void)imagePickerController:(UIImagePickerController *)picker didFinishPickingMediaWithInfo:(NSDictionary *)info
336 {
337 [picker dismissViewControllerAnimated:YES completion:nil];
338 //1.取出选取的图片
339 UIImage *image=info[UIImagePickerControllerOriginalImage];
340
341 //2.添加图片到相册中
342 [self.photoView addImage:image];
343 }
344 @end

网络请求 get post的更多相关文章

  1. Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求

    上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...

  2. Android之三种网络请求解析数据(最佳案例)

    AsyncTask解析数据 AsyncTask主要用来更新UI线程,比较耗时的操作可以在AsyncTask中使用. AsyncTask是个抽象类,使用时需要继承这个类,然后调用execute()方法. ...

  3. IOS开发之—— 在AFN基础上进行的网络请求的封装

    网络请求的思路:如果请求成功的话AFN的responseObject就是解析好的. 1发送网络请求:get/post/或者别的 带上URL,需要传的参数 2判断后台网络状态码有没有请求成功: 3 请求 ...

  4. Android,适合Restful网络请求封装

    借助volley.Gson类库. 优点 网络请求集中处理,返回值直接为预期的对象,不需要手动反序列,提高效率,使用时建立好model类即可. 使用效果 DataProess.Request(true, ...

  5. Android okHttp网络请求之Json解析

    前言: 前面两篇文章介绍了基于okHttp的post.get请求,以及文件的上传下载,今天主要介绍一下如何和Json解析一起使用?如何才能提高开发效率? okHttp相关文章地址: Android o ...

  6. 阶段一:通过网络请求,获得并解析JSON数据(天气应用)

    “阶段一”是指我第一次系统地学习Android开发.这主要是对我的学习过程作个记录. 在上一篇阶段一:解析JSON中提到,最近在写一个很简单的天气预报应用.即使功能很简单,但我还是想把它做成一个相对完 ...

  7. NSURLSession网络请求

    个人感觉在网上很难找到很简单的网络请求.或许是我才疏学浅 ,  所有就有了下面这一段 , 虽然都是代码 , 但是全有注释 . //1/获取文件访问路径 NSString *path=@"ht ...

  8. 【Swift】Alamofile网络请求数据更新TableView的坑

    写这篇BLOG前,有些话不得不提一下,就仅当发发恼骚吧... 今天下午为了一个Alamofire取得数据而更新TableView的问题,查了一下午的百度(360也是见鬼的一样),竟然没有一个简单明了的 ...

  9. 【WP8.1】HttpClient网络请求、进度以及终止

    工作这么长时间,起初还是喜欢用面向程序过程的思路去写代码. 慢慢的才会用面向对象的思路分析.解决问题.也算是一点点进步吧. 最近在做一个下载音乐的功能.用到了HttpClient类. 于是就简单的写了 ...

  10. ios htttp网络请求cookie的读取与写入(NSHTTPCookieStorage)

    当你访问一个网站时,NSURLRequest都会帮你主动记录下来你访问的站点设置的Cookie,如果 Cookie 存在的话,会把这些信息放在 NSHTTPCookieStorage 容器中共享,当你 ...

随机推荐

  1. JQuery中$.ajax()方法参数详解及应用

    url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址. type: 要求为String类型的参数,请求方式(post或get)默认为get.注意其他http请求方法,例如put和 ...

  2. hdu 1531 King

    首先吐槽一下这个题目的题意描述,我看了半天才明白. 下标全部都是乱标的!!!!出题者能不能规范一点下标的写法!!!! 差分约束系统 #include<cstdio> #include< ...

  3. 生成扫描二维码下载app的二维码的方法

    进入APP store苹果应用程序商店,根据分类找到你要生成二维码的APP,然后在浏览器连接里找到ID后的一串数字就是APP的应用ID了. 安卓系统的appid 在电脑浏览器中打开应用宝官网,http ...

  4. Vue.js 组件笔记

    Vue 组件总结笔记 一. 创建组件 1. 使用组件三部曲 ( 创建, 注册, 使用 ) 2. 全局组件:Vue.component('tag', {}); 3. 局部组件: components 属 ...

  5. Spring Security(06)——AuthenticationProvider

    目录 1.1     用户信息从数据库获取 1.1.1    使用jdbc-user-service获取 1.1.2    直接使用JdbcDaoImpl 1.2     PasswordEncode ...

  6. linux mysql-server和mysql-client

    我认为server和client是DBMS的两个面向不同操作对象的工具.server是DBMS面向物理层次,包含存储数据的一系列机制.处理方法的集成:client是DBMS面向用户,提供一系列工具为用 ...

  7. jquery操作属性 attr()和 prop()兼容性问题

    jquery1.6中新加了一个方法prop(),一直没用过它,官方解释只有一句话:获取在匹配的元素集中的第一个元素的属性值. 大家都知道有的浏览器只要写disabled,checked就可以了,而有的 ...

  8. jquery拖拽效果

    <!doctype html><html lang="en"><head> <meta charset="utf-8" ...

  9. jQuery技巧大放送【转】

    1.关于页面元素的引用 通过jquery的$()引用元素包括通过id.class.元素名以及元素的层级关系及dom或者xpath条件等方法,且返回的对象为jquery对象(集合对象),不能直接调用do ...

  10. hdu_5036_Explosion(bitset优化传递闭包)

    题目链接:hdu_5036_Explosion 题意: 一个人要打开或者用炸弹砸开所有的门,每个门里面有一些钥匙,一个钥匙对应一个门,有了一个门的钥匙就能打开相应的门,告诉每个门里面有哪些门的钥匙,问 ...