React Native socket.io客户端连接成功,但两端均未收到发射

时间:2019-02-09 18:09:56

标签: sockets react-native socket.io

我正在尝试使Socket-io服务器与iOS应用之间的通信正常进行。设备根据两个日志进行连接,但是来自客户端或服务器的任何socket.emit()操作都不会触发另一端的相应.on()事件。这是一个产生此问题的最小示例。

服务器代码:

from aiohttp import web
import socketio

sio = socketio.AsyncServer()
app = web.Application()
sio.attach(app)

@sio.on('connect', namespace='/mp')
async def connect(sid, environ):
    print("connect ", sid)

@sio.on('chat message', namespace='/mp')
async def message(sid, data):
    print("message ", data)

@sio.on('disconnect', namespace='/mp')
def disconnect(sid):
    print('disconnect ', sid)

if __name__ == '__main__':
    web.run_app(app)

客户端代码(React Native应用)

window.navigator.userAgent = 'ReactNative';
import React from "react"
import openSocket from "socket.io-client"
import { StyleSheet, Text, View, FlatList } from "react-native"
console.ignoredYellowBox = ["Remote debugger"]
import { YellowBox } from "react-native"
YellowBox.ignoreWarnings([
    "Unrecognized WebSocket connection option(s) `agent`, `perMessageDeflate`, `pfx`, `key`, `passphrase`, `cert`, `ca`, `ciphers`, `rejectUnauthorized`. Did you mean to put these under `headers`?"
])
var app = null
var socket = openSocket("http://localhost:8080/mp", {
            jsonp: false,
            reconnection: true,
            reconnectionDelay: 500,
            reconnectionAttempts: Infinity,
            transports: ["websocket"]
        })

export default class App extends React.Component {
    constructor(props) {
        super(props)
        app = this

        socket.on("connect", function() {
            console.log("connected")
            socket.emit("message", "test")
        })

    }

    render() {
        app = this
        return (
            <View style={styles.container}>
                <Text>Open up App.js to start working on your app!</Text>
            </View>
        )
    }
}

const styles = StyleSheet.create({
    container: {
        flex: 1,
        backgroundColor: "#fff",
        marginLeft:20,
        marginTop: 40,
    }
})

1 个答案:

答案 0 :(得分:0)

原来的问题是我正在向服务器发送事件message,但是服务器正在侦听事件chat message(我混合了事件名称及其功能)。即使这样,服务器到客户端的通信仍然无法正常工作,所以我想这是更多的调试工作:P