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 前言:近期研究了一下语音识别,从百度语音识别到讯飞语音识别:首先说一下个人 ...
随机推荐
- 线程同步工具之CountDownLatch
CountDownLatch,一个同步辅助类,在完成一组其他线程汇总执行的操作前,它允许一个或多个线程一直等待 主要方法: public CountDownLatch(int count); ...
- 【微信】微信小程序 调用this.setData报错this.setData is not a function;
在调用方法过程中 报错如下: 代码如下: Page({ /** * 页面的初始数据 */ data: { userLocalInfo:'用户地址' }, /** * 返回swapping页面 */ b ...
- JAVA常见算法题(十七)
package com.xiaowu.demo; //输出九九乘法表. public class Demo17 { public static void main(String[] args) { t ...
- kubernetes API Server安全
用户访问API Server(以下简称Server),K8S的安全检查步骤:认证和授权. 认证解决用户是谁的问题,就是验证用户名密码;授权解决用户能做什么的问题,就是检查该用户是否拥有权限访问请求的资 ...
- 矩阵压缩写法 scipy spark.ml.linalg里都有,CRS,CCS
CRS 表示:Compressed Row Storage CCS 表示:Compressed Column Storage CRS的表示参考: https://blog.csdn.net/buptf ...
- Hadoop之Flume详解
1.日志采集框架Flume 1.1 Flume介绍 Flume是一个分布式.可靠.和高可用的海量日志采集.聚合和传输的系统. Flume可以采集文件,socket数据包等各种形式源数据,又可以将采集到 ...
- 2017.5.1 java动态代理总结
参考来自:http://www.cnblogs.com/jqyp/archive/2010/08/20/1805041.html 1.代理模式 代理类和委托类有相同接口. 代理类负责为委托类:预处理消 ...
- 飘逸的python - __get__ vs __getattr__ vs __getattribute__以及属性的搜索策略
差别: __getattribute__:是无条件被调用.对不论什么对象的属性訪问时,都会隐式的调用__getattribute__方法,比方调用t.__dict__,事实上运行了t.__getatt ...
- Transportation poj1040
Ruratania is just entering capitalism and is establishing new enterprising activities in many fields ...
- 单一按钮显示/隐藏&&提示框效果
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...