zoukankan      html  css  js  c++  java
  • iOS之网络数据下载和JSON解析

    iOS之网络数据下载和JSON解析

    简介   

        在本文中笔者将要和大家介绍iOS中如何利用NSURLConnection从网络上下载数据,如何解析下载下来的JSON数据格式,以及如何显示数据和图片的异步下载显示

        涉及到的知识点

    1.NSURLConnection异步下载和封装

    2.JSON格式和JSON格式解析

    3.数据显示和使用SDWebImage异步显示图片

    内容 

    1.网络下载基础知识介绍

    什么是网络应用?

        一般情况下, iPhone的计算机, 照相机不需要从网络上下载数据也能运行, 所以这种类型的应用是本地应用, 但是iPhone上绝大多数的应用都需要网络才能运行, 例如QQ, 微信, 虾米音乐, 所以在iOS开发中需要知道如何从网络上下载数据。

    网络应用的程序结构

      网络应用不同于本地应用, 网络应用的数据是从网络上下载下来的, 所以需要在网络上运行一个程序为应用提供数据, 或者提供服务, 那么这个网络应用一般称为客户端, 而网络上运行的服务称为服务端。

    常见的网络接口形式

      iOS网络应用常见的数据接口一半都是HTTP形式的URL地址, 例如爱限免应用首页的数据地址为http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id=

      在项目中一般使用一些开源库通过这种网址下载数据. 例如AFNetworking。

     

    常见的数据格式

      iOS开发中常见的数据格式有两种, 一种是JSON格式, 另外种是XML格式, 相对来说, JSON格式使用的比较多。

    界面开发的一般流程

        iOS中开发一个界面, 需要界面效果图, 界面素材资源, 和网络接口

        开发的流程一般如下所示

        1, 下载数据

        2, 解析JSON或XML数据, 创建数据模型model

        3, 使用控件显示数据, 必要的时候定制视图, 例如定制cell

     

    2.NSURLConnection使用

    NSURLConnection同步下载

    //    NSURLConnection同步下载
    -(void)testNSURLConnectionSynDownLoadData
    {
        NSString *urlstring=@"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id=";
    //     发送同步URL请求
    //
        NSURL *url=[NSURL URLWithString:urlstring];
        NSError *error=nil;
        NSURLRequest *request=[NSURLRequest requestWithURL:url];
        
        NSData *data=[NSURLConnection sendSynchronousRequest:request returningResponse:nil error:&error];
        
        if(error==nil)
        {
            NSString *str=[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
            NSLog(@"str:%@",str);
            
        }
        else{
            NSLog(@"下载失败");
        }
    //
    }

    NSURLConnection异步下载

    //    NSURLConnection异步下载
    #pragma mark 异步下载
    -(void)testNSURLConnectionAsyncDownloadData
    {
        _data=[[NSMutableData alloc]init];
        NSString *urlstring=@"http://iappfree.candou.com:8080/free/applications/limited?currency=rmb&page=1&category_id=";
        //    发起了一个URL异步下载请求
        //    异步:执行了方法之后下载,立即返回,下载过程在后台(多线程)执行
        _connection=[[NSURLConnection alloc]initWithRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:urlstring]] delegate:self startImmediately:YES];
        
    }
    //代理方法,接受到服务器响应执行
    -(void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response
    {
        NSLog(@"接受到服务器响应执行");
    }
    //代理方法:接收到数据时执行
    //数据较大时,可能多次执行
    -(void)connection:(NSURLConnection *)connection didReceiveData:(NSData *)data
    {
        [_data appendData:data];
    }
    //代理方法:数据下载完成
    -(void)connectionDidFinishLoading:(NSURLConnection *)connection
    {
        NSString *str=[[NSString alloc]initWithData:_data encoding:NSUTF8StringEncoding ];
        NSLog(@"str:%@",str);
        
        NSDictionary *dic=[NSJSONSerialization JSONObjectWithData:_data options:NSJSONReadingMutableContainers error:nil];
        NSLog(@"dic=%@",dic);
    //    获取
    //    NSArray *arr=dic[@"applications"];
        NSArray *arr=[dic valueForKey:@"applications"];
        for(NSDictionary *dict in arr)
        {
            NSLog(@"name=%@",dict[@"name"]);
        }
    }
    //可以不写
    -(void)connection:(NSURLConnection *)connection didFailWithError:(NSError *)error
    {
        NSLog(@"error:%@",error);
    }

    3.JSON格式说明和格式工具

    4.一个完整界面的实现

  • 相关阅读:
    js- 类数组对象
    js- caller、 callee
    ES6 声明变量的6种方法
    Vue 之 element-ui upload组件的文件类型
    js中call、apply和bind的区别
    Vue 之 Vue.nextTick()
    DocumentFragment --更快捷操作DOM的途径
    Js 编程题汇总
    &#65279
    网站添加变量后变成空白
  • 原文地址:https://www.cnblogs.com/tianlugesanghua/p/4384511.html
Copyright © 2011-2022 走看看