一.Socket:

  • Socket又称”套接字"
  • 网络上的两个程序通过一个双向的通信链接实现数据的交换,这个连接的一端成为一个socket
  • 应用程序通常通过”套接字”向网络发出请求或者应答网络请


二.网络通信的要素

  • 网络上的请求就是通过socket来建立链接然后互相通信
  • ip地址(网络上主机设备的唯一标识)
  • 端口号(定位程序)

用于标示进程的逻辑地址,不同进程的标示

有效端口:0~65535,其中0~1024由系统使用或者保留端口,开发中建议使用1024以上的端口

  • 传输协议
        通信的规则-->常见协议:TCP  UDP
 

 三.TCP和UDP
TCP(传输控制协议)
  • 建立链接,形成传输数据的通道
  • 在链接中进行打暑假传输(数据不受到限制 )
  • 通过三次握手完成链接,是可靠协议,安全送达
  • 必须建立链接,效率会稍低
UDP(用户数据报协议)
  • 将数据及源和目的封装成数据包中,不需要建立链接
  • 每个数据报的大小限制在64k之内
  • 因为无需链接,因此是不可靠协议
  • 不需要建立链接,速度快

四.Socket通信流程图


五.实现Socket服务端监听

  • 实现socket的方法
        1.使用c语言实现
        2.使用cocoaAsyncSocket(OC)第三方框架,内部是对C的封装
  • Telnet命令
        telnet host port/telnet --> 192.168.10.10 5288
       1.telnet命令是链接服务器上的某个端口对应的服务
       2.host :  系统偏好-->网络-->IP
       3.host:   有效端口:0~65535,其中0~1024由系统使用或者保留端口,开发中建议使用1024以上的端口
 

六.代码的简单实现
  • 添加第三方框架cocoaAsyncSocket--->下载地址  https://github.com/robbiehanson/CocoaAsyncSocket
  • 创建工程: 从第三方框架中拉入 GCDAsyncSocket.h  GCDAsyncSocket.m

  • 创建服务监听对象
#import "ServiceListen.h"
//引入头文件
#import "GCDAsyncSocket.h"
@interface ServiceListen()<GCDAsyncSocketDelegate>
//服务端对象
@property(nonatomic,strong)GCDAsyncSocket *serverSocket;
//保存客户端对象
@property(nonatomic,strong)NSMutableArray *NewSockets;//客户端socket对象 @end
@implementation ServiceListen
/**
* 懒加载
*/
-(NSMutableArray *)NewSockets
{
if (_NewSockets==nil) {
_NewSockets=[NSMutableArray new];
}
return _NewSockets;
}
/**
* 开启服务方法的实现
*/
-(void)start{
//开启10086服务
//服务端的socket只监听 有没客户端请求链接
GCDAsyncSocket *serverSocket = [[GCDAsyncSocket alloc] initWithDelegate:self delegateQueue:dispatch_get_global_queue(, )];
//绑定端口,并开启监听,代表10086服务已经开启
NSError *error=nil;
[serverSocket acceptOnPort: error:&error];
if (!error) {
NSLog(@"10086服务开启成功");
}
else
{
NSLog(@"开启失败%@",error);
}
self.serverSocket=serverSocket; } #pragma mark 有客户端socket链接到服务器
/**
* 有客户端socket链接到服务器调用
*
* @param sock 服务端
* @param newSocket 客户端
*/
-(void)socket:(GCDAsyncSocket *)sock didAcceptNewSocket:(GCDAsyncSocket *)newSocket
{
NSLog(@"服务端serverSocket %@",sock);
NSLog(@"客户端newSocket %@",newSocket);
//保存客户端的socket
[self.NewSockets addObject:newSocket];
//提供服务
NSMutableString *serverStr = [NSMutableString string];
[serverStr appendString:@"欢迎光临!!!请输入下面的数字选择服务!\n"];
[serverStr appendString:@"[0]在线充值\n"];
[serverStr appendString:@"[1]在线投诉\n"];
[serverStr appendString:@"[2]优惠信息\n"];
[serverStr appendString:@"[3]特殊服务\n"];
[serverStr appendString:@"[4]退出\n"];
[newSocket writeData:[serverStr dataUsingEncoding:NSUTF8StringEncoding] withTimeout:- tag:]; //监听客户端有没有数据上传
//Timeout:-1 代表不超时
//tag:标识作用,现在不用
[newSocket readDataWithTimeout:- tag:];
}
#pragma mark 读取客户端的请求的数据
/**
* 读取客户端的请求的数据
*
* @param sock 客户端
* @param data 数据
* @param tag 标记
*/
-(void)socket:(GCDAsyncSocket *)sock didReadData:(NSData *)data withTag:(long)tag
{
//1:NSData转成NSString
NSString *str=[[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
NSLog(@"读取数据 sock: %@ %@",sock,str);
//获取客户端返回的数据
NSInteger code = [str integerValue];
//默认给客户端的数据
NSString *reponseStr=nil;
switch (code) {
case :
reponseStr = @"没有充值服务....\n";
break;
case :
reponseStr = @"当前没有员工....\n";
break;
case :
reponseStr = @"打折优惠5折....\n";
break;
case :
reponseStr = @"特殊服务一个....\n";
break;
case :
reponseStr = @"退出成功....\n";
break; default:
break;
} //2.处理请求,返回数据给客户端
[sock writeData:[reponseStr dataUsingEncoding:NSUTF8StringEncoding] withTimeout:- tag:];
if (code==) {
//移除客户端
[self.NewSockets removeObject:sock];
}
#warning 每次读完数据后,都要调用一次监听数据的方法
[sock readDataWithTimeout:- tag:];
}
  • 实例化一个服务监听对象,开始监听
#import <Foundation/Foundation.h>
#import "ServiceListen.h"
int main(int argc, const char * argv[]) {
@autoreleasepool {
// insert code here...
NSLog(@"Hello, World!");
//创建一个服务监听对象
ServiceListen *listen=[[ServiceListen alloc] init];
//开始监听
[listen start];
//开启主运行循环,让服务不能停
[[NSRunLoop mainRunLoop]run]; }
return ;
}
  • 运行程序 ,打开终端-->链接服务器

Socket的简单使用的更多相关文章

  1. socket.io简单入门(一.实现简单的图表推送)

    引子:随着nodejs蓬勃发展,虽然主要业务系统因为架构健壮性不会选择nodejs座位应用服务器.但是大量的内部系统却可以使用nodejs试水,大量的前端开发人员转入全堆开发也是一个因素. 研究本例主 ...

  2. socket.io简单说明及在线抽奖demo

    socket.io简单说明及在线抽奖demo socket.io 简介 Socket.IO可以实现实时双向的基于事件的通信. 它适用于各种平台,浏览器或设备,也同样注重可靠性和速度. socket.i ...

  3. 运用socket实现简单的服务器客户端交互

    Socket解释: 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为一个socket. Socket的英文原义是“孔”或“插座”.作为BSD UNIX的进程通信机制,取后一种意 ...

  4. java Socket实现简单在线聊天(二)

    接<java Socket实现简单在线聊天(一)>,在单客户端连接的基础上,这里第二步需要实现多客户端的连接,也就需要使用到线程.每当有一个新的客户端连接上来,服务端便需要新启动一个线程进 ...

  5. java Socket实现简单在线聊天(一)

    最近的项目有一个在线网页交流的需求,由于很久以前做过的demo已经忘记的差不多了,因此便重新学习一下. 我计划的大致实现步骤分这样几大步: 1.使用awt组件和socket实现简单的单客户端向服务端持 ...

  6. Java的Socket通信简单实例

    服务端 package testlxd; import java.io.BufferedReader; import java.io.IOException; import java.io.Input ...

  7. C#中使用Socket实现简单Web服务器

    上一篇博客中介绍了怎样使用socket访问web服务器.关键有两个: 熟悉Socket编程: 熟悉HTTP协议. 上一篇主要是通过socket来模拟浏览器向(任何)Web服务器发送(HTTP)请求,重 ...

  8. Socket通信 简单实现私聊、群聊(dos命令下)

    很久以前的一个Demo,这里服务器只做转发功能,根据ID地址和端口号来标识身份,群聊和私聊只是简单实现, 服务器代码如下: import java.util.*; import java.io.*; ...

  9. C#基于Socket的简单聊天室实践

    序:实现一个基于Socket的简易的聊天室,实现的思路如下: 程序的结构:多个客户端+一个服务端,客户端都是向服务端发送消息,然后服务端转发给所有的客户端,这样形成一个简单的聊天室功能. 实现的细节: ...

随机推荐

  1. 从零开始学习jQuery (一) 入门篇

    本系列文章导航 从零开始学习jQuery (一) 入门篇 一.摘要 本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案,  即使你会使用jQuery也能在阅读中发现些 ...

  2. node.js下LDAP查询实践

    目标: 从一个LDAP Server获取uid=kxh的用户数据 LDAP地址为:ldap://10.233.21.116:389 在工程根目录中,先npm一个LDAP的访问库ldpajs npm i ...

  3. 判断JS对象是否拥有某属性

    两种方式,但稍有区别 1.in 运算符  

  4. C++ VS2012 内存泄露检测

    在VS2012中添加部分代码,可以起到检测内存泄露的作用. 今天刚刚收到的解决办法,原理还不是很清楚.先分享出来 1. 头文件中添加以下代码 #ifdef _DEBUG #define DEBUG_C ...

  5. Redis系列一之数据结构

    一.Redis简介 redis是一个高性能的key-value非关系数据库,它可以存键(key)与5种不同类型的值(value)之间的映射(mapping),支持存储的value类型包括:String ...

  6. Scalaz(17)- Monad:泛函状态类型-State Monad

    我们经常提到函数式编程就是F[T].这个F可以被视为一种运算模式.我们是在F运算模式的壳子内对T进行计算.理论上来讲,函数式程序的运行状态也应该是在这个运算模式壳子内的,也是在F[]内更新的.那么我们 ...

  7. Scalaz(15)- Monad:依赖注入-Reader besides Cake

    我们可以用Monad Reader来实现依赖注入(dependency injection DI or IOC)功能.Scala界中比较常用的不附加任何Framework的依赖注入方式可以说是Cake ...

  8. maven 跳过测试 打包 及上传命令

    [main] ERROR org.apache.maven.cli.MavenCli - Failed to execute goal org.apache.maven.plugins:maven-s ...

  9. lodash常用方法1--查询

    1.find var _ = require('lodash'); var user1 = { name: 'zhangsan', height: 180, weight: 120 }; var us ...

  10. docker nginx1.7.6+keepalived实现双机热备

    0.前提条件 环境两台ubuntu版本14.04 64位系统(并获取root权限) 假设两台服务器ip为:172.16.34.214(master),172.16.34.215(backup),kee ...