我有一个Ionic3应用程序,该应用程序在特定视图上连接到视图即可进入并订阅Websocket可观察/观察者服务:
subscribtion: Subscription;
ionViewDidEnter() {
this.subscribtion = this.socket.message.subscribe(msg => {
let configs = <Configs>msg.data
this.inputs = configs.inputs;
});
this.socket.message.next(this.enterMessage);
}
然后,在退出视图时,退订:
ionViewWillLeave() {
this.socket.message.next(this.quitMessage);
this.subscribtion.unsubscribe();
}
但是,如果我重新进入视图,它将不会重新连接到websocket。我该怎么办?
这里是socket和websocket.ts:
@Injectable()
export class SocketProvider {
public message: Subject<Message>;
constructor(private socket: WebsocketProvider, @Inject('server') private server) {
console.log('Hello SocketProvider Provider');
let wsAddr = this.server.webSocketUrl();
this.message = <Subject<Message>>socket
.connect(wsAddr)
.map((response: MessageEvent): Message => {
let data = JSON.parse(response.data);
return data;
})
}
}
private subject: Rx.Subject<MessageEvent>;
public connect(url): Rx.Subject<MessageEvent> {
if (!this.subject) {
this.subject = this.create(url);
//console.log('successfully Connnect: ' + url);
}
return this.subject;
}
public create(url): Rx.Subject<MessageEvent> {
let ws = new WebSocket(url);
let observable = Rx.Observable.create(
(obs: Rx.Observer<MessageEvent>) => {
ws.onmessage = obs.next.bind(obs);
ws.onerror = obs.error.bind(obs);
ws.onclose = obs.complete.bind(obs);
return ws.close.bind(ws);
}
)
let observer = {
next: (data: Object) => {
if (ws.readyState === WebSocket.OPEN) {
ws.send(JSON.stringify(data));
}
}
}
return Rx.Subject.create(observer, observable);
}
}
答案 0 :(得分:1)
我找到了解决方法:
我将socket.ts中构造函数中的代码移到我在IonViewEnter()中调用的connect函数中,并重新初始化WebSocketProvider对象:
constructor(private socket: WebsocketProvider, @Inject('server') private server) {
console.log('Hello SocketProvider Provider');
}
connect() {
console.log("try to connect eb socket");
this.socket = new WebsocketProvider;
let wsAddr = this.server.webSocketUrl();
//let wsAddr = 'ws://192.168.0.110:8181';
this.message = <Subject<Message>>this.socket
//.connect('wss://echo.websocket.org')
.connect(wsAddr)
.map((response: MessageEvent): Message => {
try {
let data = JSON.parse(response.data);
return data;
}catch(e) {
alert(e);
console.log("receive invalid JSON message: ");
console.log(response.data);
}
})
}