iOS中 HTTP/Socket/TCP/IP通信协议具体解释 韩俊强的博客
简介:
// OSI(开放式系统互联), 由ISO(国际化标准组织)制定
// 1. 应用层
// 2. 表示层
// 3. 会话层
// 4. 传输层
// 5. 网络层
// 6. 数据链接层
// 7. 物理层 // TCP/IP, 由美国国防部制定
// 1. 应用层, HTTP, FTP, SMTP, DNS
// 2. 传输层, TCP, UDP
// 3. 网络层, IP
// 4. 链路层, ARP, RARP // HTTP(短连接)
// 1. 建立链接, 三次握手
// 2. 断开链接, 四次挥手 // 数据报文->数据包->数据帧->比特流(二进制)-->比特流->数据帧->数据包->数据报文 // socket, "插口", "套接字", 长连接, 存在于应用层和传输层之间, 提供一种封装, 方便进行通信
以下具体解释Socket通信:
布局例如以下:
引进框架:
服务端代码:
// Created by 韩俊强 on 15/12/25.
// Copyright © 2015年 韩俊强. All rights reserved. #import "ViewController.h"
// 使用CocoPods使用<>, 能够指定路径
#import <CocoaAsyncSocket/CocoaAsyncSocket.h>
#import "GNASocket.h" @interface ViewController ()<GCDAsyncSocketDelegate> @property (weak, nonatomic) IBOutlet UITextField *portTF;
@property (weak, nonatomic) IBOutlet UITextView *message; // 多行文本输入框
@property (weak, nonatomic) IBOutlet UITextField *content; @property (nonatomic, strong) GCDAsyncSocket *clientSocket;// 为client生成的socket // serversocket
@property (nonatomic, strong) GCDAsyncSocket *serverSocket; @end @implementation ViewController - (void)viewDidLoad
{
[super viewDidLoad];
} // 服务端监听某个端口
- (IBAction)listen:(UIButton *)sender
{
// 1. 创建serversocket
self.serverSocket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_main_queue()]; // 2. 开放哪些端口
NSError *error = nil;
BOOL result = [self.serverSocket acceptOnPort:self.portTF.text.integerValue error:&error]; // 3. 推断端口号是否开放成功
if (result) {
[self addText:@"端口开放成功"];
} else {
[self addText:@"端口开放失败"];
}
} // 发送
- (IBAction)sendMessage:(UIButton *)sender
{
NSData *data = [self.content.text dataUsingEncoding:NSUTF8StringEncoding];
[self.clientSocket writeData:data withTimeout:-1 tag:0]; GNASocket *socket = [GNASocket defaultScocket];
[socket.mySocket readDataWithTimeout:-1 tag:0];
} // 接收消息
- (IBAction)receiveMassage:(UIButton *)sender
{
[self.clientSocket readDataWithTimeout:-1 tag:0];
} // textView填写内容
- (void)addText:(NSString *)text
{
self.message.text = [self.message.text stringByAppendingFormat:@"%@\n", text];
} - (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning]; } #pragma mark - GCDAsyncSocketDelegate
// 当client链接server端的socket, 为client单生成一个socket
- (void)socket:(GCDAsyncSocket *)sock didAcceptNewSocket:(GCDAsyncSocket *)newSocket
{
[self addText:@"链接成功"];
//IP: newSocket.connectedHost
//端口号: newSocket.connectedPort
[self addText:[NSString stringWithFormat:@"链接地址:%@", newSocket.connectedHost]];
[self addText:[NSString stringWithFormat:@"端口号:%hu", newSocket.connectedPort]];
// short: %hd
// unsigned short: %hu // 存储新的端口号
self.clientSocket = newSocket;
} - (void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag
{
NSString *message = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
[self addText:message];
} @end
client代码:
// Created by 韩俊强 on 15/12/25.
// Copyright © 2015年 韩俊强. All rights reserved.
// #import "SecondViewController.h"
#import <CocoaAsyncSocket.h>
#import "GNASocket.h" @interface SecondViewController ()<GCDAsyncSocketDelegate> @property (weak, nonatomic) IBOutlet UITextField *addressTF;
@property (weak, nonatomic) IBOutlet UITextField *portTF;
@property (weak, nonatomic) IBOutlet UITextField *message; @property (weak, nonatomic) IBOutlet UITextView *content; @property (nonatomic, strong) GCDAsyncSocket *socket; @end @implementation SecondViewController - (void)viewDidLoad
{
[super viewDidLoad]; } // 和server进行链接
- (IBAction)connect:(UIButton *)sender
{
// 1. 创建socket
self.socket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_main_queue()]; // 2. 与server的socket链接起来
NSError *error = nil;
BOOL result = [self.socket connectToHost:self.addressTF.text onPort:self.portTF.text.integerValue error:&error]; // 3. 推断链接是否成功
if (result) {
[self addText:@"client链接server成功"];
} else {
[self addText:@"client链接server失败"];
}
} // 接收数据
- (IBAction)receiveMassage:(UIButton *)sender
{
[self.socket readDataWithTimeout:-1 tag:0];
} // 发送消息
- (IBAction)sendMassage:(UIButton *)sender
{
[self.socket writeData:[self.message.text dataUsingEncoding:NSUTF8StringEncoding] withTimeout:-1 tag:0];
} // textView填写内容
- (void)addText:(NSString *)text
{
self.content.text = [self.content.text stringByAppendingFormat:@"%@\n", text];
} - (void)didReceiveMemoryWarning
{
[super didReceiveMemoryWarning];
} #pragma mark - GCDAsyncSocketDelegate // client链接server端成功, client获取地址和端口号
- (void)socket:(GCDAsyncSocket *)sock didConnectToHost:(NSString *)host port:(uint16_t)port
{
[self addText:[NSString stringWithFormat:@"链接server%@", host]]; GNASocket *socket = [GNASocket defaultScocket];
socket.mySocket = self.socket;
} // client已经获取到内容
- (void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag
{
NSString *content = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
[self addText:content];
} @end
为通信传值写一个单例:
//.h
#import <Foundation/Foundation.h>
#import <CocoaAsyncSocket.h> @interface GNASocket : NSObject @property (nonatomic, strong) GCDAsyncSocket *mySocket; + (GNASocket *)defaultScocket; @end //.m #import "GNASocket.h" @implementation GNASocket + (GNASocket *)defaultScocket
{
static GNASocket *socket = nil;
static dispatch_once_t onceToken;
dispatch_once(&onceToken, ^{
socket = [[GNASocket alloc] init];
});
return socket;
} @end
终于效果:
iOS开发人员交流群:446310206
GitHub 项目地址喜欢记得start一下哦!
iOS中 HTTP/Socket/TCP/IP通信协议具体解释 韩俊强的博客的更多相关文章
- iOS中 HTTP/Socket/TCP/IP通信协议详解 韩俊强的博客
每日更新关注:http://weibo.com/hanjunqiang 新浪微博 简单介绍: // OSI(开放式系统互联), 由ISO(国际化标准组织)制定 // 1. 应用层 // 2. 表示层 ...
- iOS中 本地通知/本地通知详解 韩俊强的博客
布局如下:(重点讲本地通知) iOS开发者交流QQ群: 446310206 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 Notification是智能手机应用编 ...
- iOS中崩溃调试的使用和技巧总结 韩俊强的博客
每日更新关注:http://weibo.com/hanjunqiang 新浪微博 在iOS开发调试过程中以及上线之后,程序经常会出现崩溃的问题.简单的崩溃还好说,复杂的崩溃就需要我们通过解析Cras ...
- iOS中 CocoaPods Mac App的安装和使用 韩俊强的博客
CocoaPods Mac App的安装和使用 CocoaPods桌面应用版下载地址:https://cocoapods.org/app打开应用会提示你是否安装命令行工具,选择install就也可以在 ...
- iOS中 基于LBXScan库二维码扫描 韩俊强的博客
每日更新关注:http://weibo.com/hanjunqiang 新浪微博 首先声明这个二维码扫描是借助于zxing. 功能模块都完全封装好了,不过界面合你口味,直接使用就好,如果不合口味,后 ...
- iOS中 动态启动图GIF的简单设置 韩俊强的博客
// 设定位置和大小 CGRect frame = CGRectMake(50,340,[UIScreen mainScreen].bounds.size.width / 2,[UIScreen ma ...
- iOS中 HTTP/Socket/TCP/IP通信协议详解
// OSI(开放式系统互联), 由ISO(国际化标准组织)制定 // 1. 应用层 // 2. 表示层 // 3. 会话层 // 4. 传输层 // 5. 网络层 // 6. 数据链接层 // 7. ...
- iOS中 扫描二维码/生成二维码具体解释 韩俊强的博客
近期大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 指示根视图: se ...
- iOS中 语音识别功能/语音转文字教程具体解释 韩俊强的博客
原文地址:http://blog.csdn.net/qq_31810357/article/details/51111702 前言:近期研究了一下语音识别,从百度语音识别到讯飞语音识别:首先说一下个人 ...
随机推荐
- Vue + Webpack + Vue-loader 系列教程
http://www.cnblogs.com/terry01/p/5953464.html 介绍 Vue-loader 是什么? vue-loader 是一个加载器,能把如下格式的 Vue 组件转化成 ...
- espresso 元素遮挡问题。
在使用espresso进行测试的时候,点击一个横向列表的时候会在点击的项目下出现对应的横线. 实现方式是在FrameLayout下放两个TextView, 一个TextView包含下划线,默认是Fra ...
- Docker删除全部镜像和容器
杀死所有正在运行的容器 docker kill $(docker ps -a -q) 删除所有已经停止的容器 docker rm $(docker ps -a -q) 删除所有未打 dangling ...
- JAVA常见算法题(四)
package com.xiaowu.demo; /** * 将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5. * * * @author WQ * */ public class ...
- 关于container_of和list_for_each_entry 及其相关函数的分析
Linux代码看的比较多了,经常会遇到container_of和list_for_each_entry,特别是 list_for_each_entry比较多,因为Linux经常用到链表,虽然知道这些函 ...
- ElasticSearch5.5.2常用命令
1.启动 转到elasticsearch-5.5.2\bin目录: 打开命令行输入:elasticsearch 2.ELasticsearch集群已经启动并且正常运行 curl http://127. ...
- php不重新编译添加模块
php不重新编译添加模块 本文以安装mysqli模块为例 一.检查 1:首先保证php-fpm能正常启动 2:查看当前已安装的php模块是否有mysqli [root@web01 ~]# /appli ...
- flask和pymongo的完美搭配
1.如何进行mongo数据库的链接 import pymongo client = pymongo.MongoClient(host='192.168.*.*', port=27017,) db_au ...
- redux VS mobx (装饰器配合使用)
前言:redux和mobx都是状态管理器,避免父级到子级再到子子级嵌套单向数据流,可以逻辑清晰的管理更新共享数据.(刷新页面redux储蓄数据即消失) 配置使用装饰器(使用高阶函数包装你的组件): n ...
- Oracle 为表空间增加数据文件
dba权限检查下 select tablespace_name, file_id, file_name, ),) total_space from dba_data_files order by ta ...