美文网首页NetworkiOS Foundations
iOS面试宝典之——网络编程秘籍

iOS面试宝典之——网络编程秘籍

作者: CodingIran | 来源:发表于2016-07-04 11:49 被阅读145次

    1.iOS中socket使用

    Socket是对TCP/IP协议的封装,Socket本身并不是协议,而是一个调用接口(API),通过Socket,我们才能使用TCP/IP协议。

    http协议 对应于应用层
    tcp协议 对应于传输层
    ip协议 对应于网络层
    三者本质上没有可比性。 何况HTTP协议是基于TCP连接的。

    TCP/IP是传输层协议,主要解决数据如何在网络中传输;而HTTP是应用层协议,主要解决如何包装数据。

    我 们在传输数据时,可以只使用传输层(TCP/IP),但是那样的话,由于没有应用层,便无法识别数据内容,如果想要使传输的数据有意义,则必须使用应用层 协议,应用层协议很多,有HTTP、FTP、TELNET等等,也可以自己定义应用层协议。WEB使用HTTP作传输层协议,以封装HTTP文本信息,然 后使用TCP/IP做传输层协议将它发送到网络上。

    SOCKET原理

    1. 套接字(socket)概念套接字(socket)是通信的基石,是支持TCP/IP协议的网络通信的基本操作单元。它是网络通信过程中端点的抽象表示,包含进行网络通信必须的五种信息:连接使用的协议,本地主机的IP地址,本地进程的协议端口,远地主机的IP地址,远地进程的协议端口。
      应 用层通过传输层进行数据通信时,TCP会遇到同时为多个应用程序进程提供并发服务的问题。多个TCP连接或多个应用程序进程可能需要通过同一个 TCP协议端口传输数据。为了区别不同的应用程序进程和连接,许多计算机操作系统为应用程序与TCP/IP协议交互提供了套接字(Socket)接口。应 用层可以和传输层通过Socket接口,区分来自不同应用程序进程或网络连接的通信,实现数据传输的并发服务。
    2. 建立socket连接建立Socket连接至少需要一对套接字,其中一个运行于客户端,称为ClientSocket,另一个运行于服务器端,称为ServerSocket。
      套接字之间的连接过程分为三个步骤:服务器监听,客户端请求,连接确认。
      服务器监听:服务器端套接字并不定位具体的客户端套接字,而是处于等待连接的状态,实时监控网络状态,等待客户端的连接请求。
      客户端请求:指客户端的套接字提出连接请求,要连接的目标是服务器端的套接字。为此,客户端的套接字必须首先描述它要连接的服务器的套接字,指出服务器端套接字的地址和端口号,然后就向服务器端套接字提出连接请求。
      连 接确认:当服务器端套接字监听到或者说接收到客户端套接字的连接请求时,就响应客户端套接字的请求,建立一个新的线程,把服务器端套接字的描述发给客户 端,一旦客户端确认了此描述,双方就正式建立连接。而服务器端套接字继续处于监听状态,继续接收其他客户端套接字的连接请求。
    3. SOCKET连接与TCP连接创建Socket连接时,可以指定使用的传输层协议,Socket可以支持不同的传输层协议(TCP或UDP),当使用TCP协议进行连接时,该Socket连接就是一个TCP连接。
    4. Socket连接与HTTP连接由 于通常情况下Socket连接就是TCP连接,因此Socket连接一旦建立,通信双方即可开始相互发送数据内容,直到双方连接断开。但在实际网络应用 中,客户端到服务器之间的通信往往需要穿越多个中间节点,例如路由器、网关、防火墙等,大部分防火墙默认会关闭长时间处于非活跃状态的连接而导致 Socket 连接断连,因此需要通过轮询告诉网络,该连接处于活跃状态。
      而HTTP连接使用的是“请求—响应”的方式,不仅在请求时需要先建立连接,而且需要客户端向服务器发出请求后,服务器端才能回复数据。
      很 多情况下,需要服务器端主动向客户端推送数据,保持客户端与服务器数据的实时与同步。此时若双方建立的是Socket连接,服务器就可以直接将数据传送给 客户端;若双方建立的是HTTP连接,则服务器需要等到客户端发送一次请求后才能将数据传回给客户端,因此,客户端定时向服务器端发送连接请求,不仅可以 保持在线,同时也是在“询问”服务器是否有新的数据,如果有就将数据传给客户端。

    下面这篇文章是AsyncSocket的使用教程,大家可以看看。

    2.网络请求中post和get的区别

    GET是用于获取数据的,POST一般用于将数据发给服务器之用。
    普遍答案

    1. GET使用URL或Cookie传参。而POST将数据放在BODY中。
    2. GET的URL会有长度上的限制,则POST的数据则可以非常大。
    3. POST比GET安全,因为数据在地址栏上不可见。

    不过也有文章说其实上面的是错误的,具体参考这篇文章

    3.远程推送

    当服务端远程向APNS推送至一台离线的设备时,苹果服务器Qos组件会自动保留一份最新的通知,等设备上线后,Qos将把推送发送到目标设备上
    远程推送的基本过程

    1. 客户端的app需要将用户的UDID和app的bundleID发送给apns服务器,进行注册,apns将加密后的device Token返回给app
    2. app获得device Token后,上传到公司服务器
    3. 当需要推送通知时,公司服务器会将推送内容和device Token一起发给apns服务器
    4. apns再将推送内容送到客户端上

    创建证书的流程:

    1. 打开钥匙串,生成CertificateSigningRequest.certSigningRequest文件
    2. 将CertificateSigningRequest.certSigningRequest上传进developer,导出.cer文件
    3. 利用CSR导出P12文件
    4. 需要准备下设备token值(无空格)
    5. 使用OpenSSL合成服务器所使用的推送证书

    本地app代码参考

    1. 注册远程通知
     - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions//中注册远程通知{[[UIApplication sharedApplication] registerForRemoteNotificationTypes:(UIRemoteNotificationTypeAlert | UIRemoteNotificationTypeBadge | UIRemoteNotificationTypeSound)];}
    
    1. 实现几个代理方法:
     //获取deviceToken令牌
     -(void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)deviceToken
    {
        //获取设备的deviceToken唯一编号
        NSLog(@"deviceToken=%@",deviceToken);
        NSString *realDeviceToken=[NSString stringWithFormat:@"%@",deviceToken];
        //去除<>
        realDeviceToken = [realDeviceToken stringByReplacingOccurrencesOfString:@"<" withString:@""];
        realDeviceToken = [realDeviceToken stringByReplacingOccurrencesOfString:@">" withString:@""];
        NSLog(@"realDeviceToken=%@",realDeviceToken);
        [[NSUserDefaults standardUserDefaults] setValue:realDeviceToken forKey:@"DeviceToken"];  //要发送给服务器
    }
     //获取令牌出错
    -(void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error
    {
        //注册远程通知设备出错
        NSLog(@"RegisterForRemoteNotification error=%@",error);
    }
    //在应用在前台时受到消息调用
    -(void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo
    {
        //打印推送的消息
        NSLog(@"%@",[[userInfo objectForKey:@"aps"] objectForKey:@"alert"]):
    }
    

    配置后台模式


    一般我们是使用开发版本的Provisioning做推送测试,如果没有问题,再使用发布版本证书的时候一般也应该是没有问题的。为了以防万一,我们可以在越狱的手机上安装我们的使用发布版证书的ipa文件(最好使用debug版本,并打印出获取到的deviceToken),安装成功后在;XCode->Window->Organizer-找到对应的设备查看console找到打印的deviceToken。
    在后台的推送程序中使用发布版制作的证书并使用该deviceToken做推送服务.使用开发和发布证书获取到的deviceToken是不一样的。

    相关文章

      网友评论

        本文标题:iOS面试宝典之——网络编程秘籍

        本文链接:https://www.haomeiwen.com/subject/icicjttx.html