webentwicklung-frage-antwort-db.com.de

Richtige Verwendung von WebSockets mit React Native

Ich bin neu in React Native, aber mit React sehr vertraut. Als Anfänger versuche ich, eine Verbindung zwischen einem Cloud-Server und Reactative mit Websockets herzustellen, wie ich es in der Dokumentation gesehen habe. Leider gibt es da draußen kein gutes Beispiel, das mir helfen könnte. Das ist alles was ich bis jetzt habe:

import React, { Component } from 'react';

import {
  AppRegistry,
  StyleSheet,
  Text,
  View,
  Button
} from 'react-native';

export default class raspberry extends Component {
  constructor(props) {
    super(props);

    this.state = { open: false };
    this.socket = new WebSocket('ws://127.0.0.1:3000');
    this.emit = this.emit.bind(this);
  }

  emit() {
    this.setState(prevState => ({ open: !prevState.open }))
    this.socket.send("It worked!")
  }

  render() {

    const LED = {
      backgroundColor: this.state.open ? 'lightgreen' : 'red',
      height: 30,
      position: 'absolute',
      flexDirection: 'row',
      bottom: 0,
      width: 100,
      height: 100,
      top: 120,
      borderRadius: 40,
      justifyContent: 'space-between'

    }

    return (
      <View style={styles.container}>
        <Button
          onPress={this.emit}
          title={this.state.open ? "Turn off" : "Turn on"}
          color="#21ba45"
          accessibilityLabel="Learn more about this purple button"
        />
        <View style={LED}></View>
      </View>
    );
  }

  componentDidMount() {
    this.socket.onopen = () => socket.send(JSON.stringify({ type: 'greet', payload: 'Hello Mr. Server!' }))
    this.socket.onmessage = ({ data }) => console.log(JSON.parse(data).payload)
  }

}

const styles = StyleSheet.create({
  container: {
    flex: 1,
    justifyContent: 'center',
    alignItems: 'center',
    backgroundColor: '#F5FCFF',
  },
  welcome: {
    fontSize: 20,
    textAlign: 'center',
    margin: 10,
  },
  instructions: {
    textAlign: 'center',
    color: '#333333',
    marginBottom: 5,
  },
});

AppRegistry.registerComponent('raspberry', () => raspberry);

Alles funktioniert gut, aber wenn ich den Knopf drücke, um eine Nachricht zu senden, ist dies der Fehler, den ich erhalte:

Nachricht kann nicht gesendet werden Unbekannte WebSocket-ID 1

Ich habe auch einen Test mit einem Js-Client gemacht und alles hat reibungslos funktioniert. 

7
Razvan Alex

code ändern

socket.send(JSON.stringify({ type: 'greet', payload: 'Hello Mr. Server!' }))

zu

this.socket.send(JSON.stringify({ type: 'greet', payload: 'Hello Mr. Server!' }))

es sollte funktionieren.

hier ist mein zu testender Code, basierend auf Ihrem Code und RN 0.45 (und einem von create -rea-native-app generierten Projekt), verbindet sich mit einem öffentlichen Websocket-Server wss://echo.websocket.org/, auf meinem Android funktioniert es einwandfrei und ich kann das Echo des Websocket-Servers sehen Nachricht, nachdem ich die Taste gedrückt habe.

import React, { Component } from 'react';

import {
    StyleSheet,
    Text,
    View,
    Button
} from 'react-native';

export default class App extends React.Component {

    constructor() {
        super();

        this.state = {
            open: false
        };
        this.socket = new WebSocket('wss://echo.websocket.org/');
        this.emit = this.emit.bind(this);
    }

    emit() {
        this.setState(prevState => ({
            open: !prevState.open
        }))
        this.socket.send("It worked!")
    }

    componentDidMount() {
        this.socket.onopen = () => this.socket.send(JSON.stringify({type: 'greet', payload: 'Hello Mr. Server!'}));
        this.socket.onmessage = ({data}) => console.log(data);
    }

    render() {

        const LED = {
            backgroundColor: this.state.open
            ? 'lightgreen'
            : 'red',
            height: 30,
            position: 'absolute',
            flexDirection: 'row',
            bottom: 0,
            width: 100,
            height: 100,
            top: 120,
            borderRadius: 40,
            justifyContent: 'space-between'
        }

        return (
            <View style={styles.container}>
                <Button onPress={this.emit} title={this.state.open
        ? "Turn off"
        : "Turn on"} color="#21ba45" accessibilityLabel="Learn more about this purple button"/>
                <View style={LED}></View>
            </View>
        );
    }
}


const styles = StyleSheet.create({
    container: {
        flex: 1,
        justifyContent: 'center',
        alignItems: 'center',
        backgroundColor: '#F5FCFF'
    },
    welcome: {
        fontSize: 20,
        textAlign: 'center',
        margin: 10
    },
    instructions: {
        textAlign: 'center',
        color: '#333333',
        marginBottom: 5
    }
});
8
qianlei

Gemäß documentation müssen Sie der Komponente den Status connected hinzufügen. Und nichts senden, wenn connected wahr ist.

export default class raspberry extends Component {
  constructor(props) {
    super(props);
    this.state = {
      open: false,
      connected: false
    };
    this.socket = new WebSocket('ws://127.0.0.1:3000');
    this.socket.onopen = () => {
      this.setState({connected:true})
    }; 
    this.emit = this.emit.bind(this);
  }

  emit() {
    if( this.state.connected ) {
      this.socket.send("It worked!")
      this.setState(prevState => ({ open: !prevState.open }))
    }
  }
}
5
oklas

Nachdem ich einige Nachforschungen angestellt hatte, stellte ich fest, dass das WebSocket sein sollte 

new WebSocket("ws://10.0.2.2:PORT/")

wobei 10.0.2.2 die localhost bedeutet

1
Razvan Alex