socket.io OC版本使用

项目地址:RTCVPSocketIO


Socket.IO client for iOS. Supports socket.io 2.0+

It’s based on a official Swift library from here: SocketIO-Client-Swift

It uses Jetfire Jetfire

引入项目

源码直接引入

image

使用简介

如果使用https 等连接注意检查工程的info.plist配置

Objective-C Example

#import "RTCVPSocketIO.h"
#import "RTCVPSocketAckEmitter.h"

NSURL* url = [[NSURL alloc] initWithString:@"https://localhost:8080"];
// 设置日志显示类
RTCVPSocketLogger *logger = [[RTCVPSocketLogger alloc]init];
// 自定义参数 
 NSMutableDictionary *params = [NSMutableDictionary dictionary];
 [params setObject:@"参数" forKey: @"id"];
  [params setObject:@"123456" forKey: @"roomId"];
RTCVPSocketIOClient* socket = [[RTCVPSocketIOClient alloc] init:url withConfig:@{@"log": @NO,
                                                 @"reconnects":@YES,
                                                 @"reconnectAttempts":@(20),
                                                 @"forcePolling": @NO,
                                                 @"secure": @YES,
                                                 @"forceNew":@YES,
                                                 @"forceWebsockets":@YES,
                                                 @"selfSigned":@YES,
                                                 @"reconnectWait":@2,
                                                 @"nsp":@"/",
                                                 @"connectParams":params,
                                                 @"logger":logger
                                    }];;

[socket on:kSocketEventConnect callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
      NSLog(@"====================kSocketEventConnect==========================");
    }];
    [socket on:kSocketEventDisconnect callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
       NSLog(@"====================kSocketEventDisconnect==========================");
    }];
    [socket on:kSocketEventError callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
       NSLog(@"====================kSocketEventError==========================");
    }];
    [socket on:kSocketEventReconnect callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
       NSLog(@"====================kSocketEventReconnect==========================");
    }];
    [socket on:kSocketEventReconnectAttempt callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
        NSLog(@"====================kSocketEventReconnectAttempt==========================");
    }];
    [socket on:kSocketEventStatusChange callback:^(NSArray *array, RTCVPSocketAckEmitter *emitter) {
       NSLog(@"====================kSocketEventStatusChange==========================");
    }];

[socket connect];

参数返回的array可能有多个,其中可以是字符串,也可能是字典;具体数据按照和服务协定;
上述在连接https的时候需要设置两个参数:secure和selfSigned的值要设为YES;http这两个参数需要设置为NO

连接服务

除了 [socket connect]; 方法,还提供设置连接超时方法,如下:

[_socket connectWithTimeoutAfter:10 withHandler:^{
    
   }];

输出库日志

     RTCVPSocketLogger *logger = [[RTCVPSocketLogger alloc]init];
    [logger onLogMsgWithCB:^(NSString *message, NSString *type) {
       
    }];

Features

  • Supports socket.io 2.0+
  • Supports binary
  • Supports Polling and WebSockets
  • Supports TLS/SSL

Installation

Carthage

Add these line to your Cartfile:

github "vascome/vpsocketio" ~> 1.0.5 # Or latest version

Run carthage update --platform ios,macosx.

自定义消息监听:

[socket on:@"notification" callback:^(NSArray *array,  RTCVPSocketAckEmitter *emitter) {
        
        
         NSLog(@"====================notification=========================="); 
    }];

request请求后响应服务:

[socket on:@"request" callback:^(NSArray *array,  RTCVPSocketAckEmitter *emitter) {
        
        emitResp  resp = ^(NSInteger code,NSString *ID){
            [emitter emitWith:@[[NSNull null],@{@"code":@(code),@"msg":ID}]];//格式根据需求处理
            NSLog(@"====================request resp==========================");
            
        };
        self.notifyInfo(@"request",array,resp);       
    }];

发送消息

1.发送需要回掉的消息

 RTCVPSocketOnAckCallback *callback = [blockSelf.socket emitWithAck:method items:@[message]];
 [callback timingOutAfter:10 callback:^(NSArray *array) {
                if ([array[0] isKindOfClass:[NSNull class]]) {
                    NSLog(@"");
                }
}];
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Socket.IO是一个实时应用程序框架,它允许服务器和客户端之进行双向通信。它提供了一种简单而强大的方式来构建实时应用程序,包括聊天应用、实时分析、实时协作等。 UniApp是一个基于Vue.js的跨平台开发框架,可以同时开发iOS、Android和Web应用。它提供了一套统一的API和组件,使得开发者可以使用一套代码构建多个平台的应用。 在UniApp中使用Socket.IO,你可以通过以下步骤进行配置和使用: 1. 安装Socket.IO库:在UniApp项目中,可以使用npm或者yarn安装Socket.IO库。在项目根目录下执行以下命令: ``` npm install socket.io-client ``` 2. 创建Socket.IO实例:在需要使用Socket.IO的页面或组件中,引入Socket.IO库,并创建一个Socket.IO实例。示例代码如下: ```javascript import io from 'socket.io-client'; // 创建Socket.IO实例 const socket = io('http://your-server-url'); ``` 3. 监听事件:通过Socket.IO实例,你可以监听服务器发送的事件,并在事件触发时执行相应的逻辑。示例代码如下: ```javascript // 监听服务器发送的消息事件 socket.on('message', (data) => { console.log('收到消息:', data); }); ``` 4. 发送事件:通过Socket.IO实例,你可以向服务器发送事件,并传递相应的数据。示例代码如下: ```javascript // 发送消息事件 socket.emit('message', 'Hello, server!'); ``` 这样,你就可以在UniApp中使用Socket.IO进行实时通信了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

简简单单lym

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值