转自: http://7097095.blog.51cto.com/7087095/1226462 已经在代码中用上
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
#import <Foundation/Foundation.h> @interface MyServer : NSObject{ BOOL isClosed;
} // 初始化服务器 -( void ) initServer;
// 读客户端数据 -( void ) readData:(NSNumber*) clientSocket;
// 向客户端发送数据 -( void ) sendData:( const char *) data;
// 在新线程中监听客户端 -( void ) startListenAndNewThread;
-( void ) closeServer;
@end |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
#import "MyServer.h" #include<stdio.h> #include<unistd.h> #include<strings.h> #include<sys/types.h> #include<sys/socket.h> #include<netinet/in.h> #include<netdb.h> #define PORT 6677 #define MAXDATASIZE 100 #define LENGTH_OF_LISTEN_QUEUE 20 #define BUFFER_SIZE 1024 #define THREAD_MAX 5 NSLock *lock; @implementation MyServer // 初始化服务器 -( void ) initServer{
//设置一个socket地址结构server_addr,代表服务器internet地址, 端口
struct sockaddr_in server_addr;
bzero(&server_addr, sizeof (server_addr)); //把一段内存区的内容全部设置为0
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = htons(INADDR_ANY);
server_addr.sin_port = htons(PORT);
//创建用于internet的流协议(TCP)socket,
//用server_socket代表服务器socket
int server_socket = socket(AF_INET,SOCK_STREAM,0);
if ( server_socket < 0)
{
printf ( "Create Socket Failed!" );
exit (1);
}
//把socket和socket地址结构联系起来
if ( bind(server_socket,( struct sockaddr*)&server_addr, sizeof (server_addr)))
{
printf ( "Server Bind Port : %d Failed!" , PORT);
exit (1);
}
//server_socket用于监听
if ( listen(server_socket, LENGTH_OF_LISTEN_QUEUE) )
{
printf ( "Server Listen Failed!" );
exit (1);
}
isClosed = NO;
while (!isClosed) //服务器端要一直运行
{
printf ( "Server start......\n" );
//定义客户端的socket地址结构client_addr
struct sockaddr_in client_addr;
socklen_t length = sizeof (client_addr);
//接受一个到server_socket代表的socket的一个连接
//如果没有连接请求,就等待到有连接请求--这是accept函数的特性
//accept函数返回一个新的socket,这个socket(new_server_socket)用于同连接到的客户的通信
//new_server_socket代表了服务器和客户端之间的一个通信通道
//accept函数把连接到的客户端信息填写到客户端的socket地址结构client_addr中
int new_client_socket = accept(server_socket,( struct sockaddr*)&client_addr,&length);
if ( new_client_socket < 0)
{
printf ( "Server Accept Failed!/n" );
break ;
}
printf ( " one client connted..\n" );
[NSThread detachNewThreadSelector:@selector(readData:)
toTarget:self
withObject:[NSNumber numberWithInt:new_client_socket]];
}
//关闭监听用的socket
close(server_socket);
NSLog(@ "%@" ,@ "server closed...." );
} // 读客户端数据 -( void ) readData:(NSNumber*) clientSocket{
char buffer[BUFFER_SIZE];
int intSocket = [clientSocket intValue];
while (buffer[0] != '-' ){
bzero(buffer,BUFFER_SIZE);
//接收客户端发送来的信息到buffer中
recv(intSocket,buffer,BUFFER_SIZE,0);
printf ( "client:%s\n" ,buffer);
}
//关闭与客户端的连接
printf ( "client:close\n" );
close(intSocket);
} // 向客户端发送数据 -( void ) sendData:( const char *) data{
} // 在新线程中监听客户端 -( void ) startListenAndNewThread{
[NSThread detachNewThreadSelector:@selector(initServer)
toTarget:self withObject:nil];
} -( void ) closeServer{
isClosed = YES;
} @end |
相关推荐
服务端CPP编写,目前是MAC上平台的工程,可以在LINUX下编写相应MAKEFILE编译 自己测试的是UBUNTU, 客户端是IOS的 现在只有一些简单的功能, 登录 注册 搜索添加好友, 简单会话 服务端编译运行 需要MYSQL 至于MAC下...
服务端CPP编写,目前是MAC上平台的工程,可以在LINUX下编写相应MAKEFILE编译 自己测试的是UBUNTU, 客户端是IOS的现在只有一些简单的功能, 登录 注册 搜索添加好友, 简单会话服务端编译运行 需要MYSQL 至于MAC下...
通过该库,用户可以非常容易地编写支持多种模式(多线程,多进程,非二进制,异步,UDP方式,协程方式)的服务器程序,WEB应用程序,数据库应用程序。从而,该库还提供了常用应用的客户端通信库(如:HTTP ,SMTP,...
一个GCDAsyncSocket 编写的TCP Echo 服务器,在ipad,iPhone测试通过
SwiftSocketIO SwiftSocketIO 是一个用 Swift 编写的 (1.x) 客户端。特征目前,SwiftSocketIO 只实现了 websocket 传输。 初始连接通过 HTTP(S) 发生,但在成功握手后立即升级连接。 如果您的服务器不支持 websocket...
RTCSignalServer一个用Golang编写的简单信号服务器。 支持简单的房间管理和消息交换。 API参考:api.md RTCClientDemo Web Android iOS(即将推出)Windows(即将推出)2.概述2.用法演示仅支持2个对等方在LAN中进行...
如果您要编写类似于当前Web的客户端项目的代码,则应使用cocos2d(),可以为Web,window,android,ios,linux,macOS构建一次性代码,以使用该工具,有一些工具可以支持创建简单的游戏,JS中的代码应避免客户机和...
如果开发人员想使用Signal,需要在客户端层使用像jQuery的JavaScript框架,并在服务端层使用.NET代码编写应用和服务。SignalR具有多种编程模型(PersistentConnections 和Hubs),它为开发人员提供了连接、消息接收...
得到RSA密钥对,产生Signature对象,对用私钥对信息(info)签名,用指定算法产生签名对象,用私钥初始化签名对象,将待签名的数据传送给签名对象(须在初始化之后),用公钥验证签名结果,使用公钥初始化签名对象,用于...
得到RSA密钥对,产生Signature对象,对用私钥对信息(info)签名,用指定算法产生签名对象,用私钥初始化签名对象,将待签名的数据传送给签名对象(须在初始化之后),用公钥验证签名结果,使用公钥初始化签名对象,用于...
:atom_symbol: React Native-一个库,为创建适用于Android和iOS的本机应用程序提供了路径。 :chart_increasing_with_yen: 节点Js-服务器端Javascript执行环境。 :alarm_clock: Socket.IO-用于实时Web应用程序...
它基于,并已用Scala编写。 与客户的通信是通过以下技术进行的: 免费的开源工具包和运行时,简化了JVM上并发和分布式应用程序的构建; 通信协议,提供全双工通信并促进服务器之间的实时数据传输; -Scala的JSON库...
Mars 是微信官方的终端基础组件,是一个使用 C 编写的业务性无关、平台性无关的基础组件。目前已接入微信 Android、iOS、Mac、Windows、WP 等客户端。主要包括以下几个部分:COMM:基础库,包括socket、线程、消息...
包含资源名称下载地址 Android 开发从入门到精通 新版Android开发教程及笔记-完整版 《Android中文教程》中文版 《android基础教程合集》 Android实例教程 会员贡献...介绍ios及android平台app应用的推广方法与渠道