我使用内置MZFayeClient
使用WebSocket
(https://github.com/m1entus/MZFayeClient)。
我需要实现长轮询技术。
怎么做?从哪儿开始?
没有关于如何做到这一点的信息(或足够的信息),或者是否有一个带有长轮询的Faye库。
答案 0 :(得分:5)
我不是IOS开发人员,但我的一个项目是帮助我的IOS团队整合Faye服务器。
在我的应用程序中,我们有一个已在rails框架上运行的faye-server用于发送通知,然后我们决定使用相同的faye-server向IOS设备发送通知。
IOS团队只需遵循:https://github.com/pcrawfor/FayeObjC
的指示self.client = [[MZFayeClient alloc] initWithURL:[NSURL URLWithString:@"ws://198.128.0.1:9292/faye"]];
ws://198.128.0.1:9292/faye // this URL is same which is used on web-app.
subscribeToChannel&其他方法与我们在web-app上使用的方法相同。
Rails应用程序的简单Faye设置。
How can I push to Faye Server from Rails Controller?
它对我有用,我希望也能帮到你..
抱歉我的英语不好;)
答案 1 :(得分:2)
sudo rackup faye.ru -E production -s thin
启动Faye服务器
Thin web server (v1.6.4 codename Gob Bluth) Maximum connections set to
1024 Listening on localhost:9292, CTRL+C to stop
检查服务器是否正常工作
curl http://localhost:9292/faye -d 'message={"channel":"/server", "data":"hello"}'
响应
[{"channel":"/server","successful":true}]
服务器日志:
[Faye::RackAdapter] Received message via HTTP POST:
"{\"channel\":\"/server\", \"data\":\"hello\"}" [Faye::Server]
Processing messages: [{"channel":"/server","data":"hello"}] (local:
false) [Faye::Server] Passing through incoming extensions:
{"channel":"/server","data":"hello"} [Faye::Server] Handling message:
{"channel":"/server","data":"hello"} (local: false)
[Faye::Engine::Proxy] Publishing message
{"channel":"/server","data":"hello"} [Faye::Server] Processing reply:
{"channel":"/server","successful":true} [Faye::Server] Passing through
outgoing extensions: {"channel":"/server","successful":true}
[Faye::Server] Returning replies:
[{"channel":"/server","successful":true}] [Faye::RackAdapter] HTTP
response: "[{\"channel\":\"/server\",\"successful\":true}]"
<强> 2。与客户合作: 下载MZFayeClient
cd FayeObjC-master/examples
pod install
open FayeObjC.xcworkspace
MZViewController.m
- (void)viewDidLoad
{
[super viewDidLoad];
self.client = [[MZFayeClient alloc] initWithURL:[NSURL URLWithString:@"http://localhost:9292/faye"]];
[self.client subscribeToChannel:@"/server" success:^{
NSLog(@"ok");
} failure:^(NSError *error) {
NSLog(@"Server %@",error);
} receivedMessage:^(NSDictionary *message) {
NSLog(@"Server %@",message);
}];
self.client.delegate = self;
}
第3。构建示例: 触摸连接:
[Faye::RackAdapter] Received message via WebSocket[hybi-13]:
"{\"supportedConnectionTypes\":[\"long-polling\",\"callback-polling\",\"iframe\",\"websocket\"],\"channel\":\"\\/meta\\/handshake\",\"minimumVersion\":\"1.0beta\",\"version\":\"1.0\"}"
[Faye::Server] Processing messages:
[{"supportedConnectionTypes":["long-polling","callback-polling","iframe","websocket"],"channel":"/meta/handshake","minimumVersion":"1.0beta","version":"1.0"}]
(local: false) [Faye::Server] Passing through incoming extensions:
{"supportedConnectionTypes":["long-polling","callback-polling","iframe","websocket"],"channel":"/meta/handshake","minimumVersion":"1.0beta","version":"1.0"}
[Faye::Server] Handling message:
{"supportedConnectionTypes":["long-polling","callback-polling","iframe","websocket"],"channel":"/meta/handshake","minimumVersion":"1.0beta","version":"1.0"}
(local: false) [Faye::Engine::Proxy] Created new client
"f68nwz5foyf1brczhmutdhclhnbtth5" [Faye::Engine::Proxy] Ping
"f68nwz5foyf1brczhmutdhclhnbtth5", 45 [Faye::Server] Processing reply:
{"channel":"/meta/handshake","successful":true,"version":"1.0","supportedConnectionTypes":["long-polling","cross-origin-long-polling","callback-polling","websocket","eventsource","in-process"],"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","advice":{"reconnect":"retry","interval":0,"timeout":45000}}
[Faye::Server] Passing through outgoing extensions:
{"channel":"/meta/handshake","successful":true,"version":"1.0","supportedConnectionTypes":["long-polling","cross-origin-long-polling","callback-polling","websocket","eventsource","in-process"],"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","advice":{"reconnect":"retry","interval":0,"timeout":45000}}
[Faye::Server] Returning replies:
[{"channel":"/meta/handshake","successful":true,"version":"1.0","supportedConnectionTypes":["long-polling","cross-origin-long-polling","callback-polling","websocket","eventsource","in-process"],"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","advice":{"reconnect":"retry","interval":0,"timeout":45000}}]
[Faye::RackAdapter] Received message via WebSocket[hybi-13]:
"{\"channel\":\"\\/meta\\/connect\",\"clientId\":\"f68nwz5foyf1brczhmutdhclhnbtth5\",\"connectionType\":\"websocket\"}"
[Faye::Server] Processing messages:
[{"channel":"/meta/connect","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","connectionType":"websocket"}]
(local: false) [Faye::Server] Passing through incoming extensions:
{"channel":"/meta/connect","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","connectionType":"websocket"}
[Faye::Server] Handling message:
{"channel":"/meta/connect","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","connectionType":"websocket"}
(local: false) [Faye::Engine::Proxy] Accepting connection from
"f68nwz5foyf1brczhmutdhclhnbtth5" [Faye::Engine::Proxy] Ping
"f68nwz5foyf1brczhmutdhclhnbtth5", 45 [Faye::RackAdapter] Received
message via WebSocket[hybi-13]:
"{\"channel\":\"\\/meta\\/subscribe\",\"clientId\":\"f68nwz5foyf1brczhmutdhclhnbtth5\",\"subscription\":\"\\/server\"}"
[Faye::Server] Processing messages:
[{"channel":"/meta/subscribe","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","subscription":"/server"}]
(local: false) [Faye::Server] Passing through incoming extensions:
{"channel":"/meta/subscribe","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","subscription":"/server"}
[Faye::Server] Handling message:
{"channel":"/meta/subscribe","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","subscription":"/server"}
(local: false) [Faye::Engine::Proxy] Subscribed client
"f68nwz5foyf1brczhmutdhclhnbtth5" to channel "/server" [Faye::Server]
Processing reply:
{"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/meta/subscribe","successful":true,"subscription":"/server"}
[Faye::Server] Passing through outgoing extensions:
{"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/meta/subscribe","successful":true,"subscription":"/server"}
[Faye::Server] Returning replies:
[{"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/meta/subscribe","successful":true,"subscription":"/server"}]
输入“hello”然后发送
[Faye::RackAdapter] Received message via WebSocket[hybi-13]:
"{\"data\":{\"text\":\"hello\"},\"clientId\":\"f68nwz5foyf1brczhmutdhclhnbtth5\",\"channel\":\"\\/browser\",\"id\":\"MQ==\"}"
[Faye::Server] Processing messages:
[{"data":{"text":"hello"},"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","id":"MQ=="}]
(local: false)
[Faye::Server] Passing through incoming extensions:
{"data":{"text":"hello"},"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","id":"MQ=="}
[Faye::Server] Handling message:
{"data":{"text":"hello"},"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","id":"MQ=="}
(local: false)
[Faye::Engine::Proxy] Publishing message
{"data":{"text":"hello"},"clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","id":"MQ=="}
[Faye::Server] Processing reply:
{"id":"MQ==","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","successful":true}
[Faye::Server] Passing through outgoing extensions:
{"id":"MQ==","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","successful":true}
[Faye::Server] Returning replies:
[{"id":"MQ==","clientId":"f68nwz5foyf1brczhmutdhclhnbtth5","channel":"/browser","successful":true}]
希望得到这个帮助。