It can be very simple to do GET, POST, PUT and DELETE requests with React Native (see the official Expo documentation https://docs.expo.io/versions/latest/react-native/network/), therefore, those requests are not interesting when we want to do a chat for example (we can talk about “real time events”).
To do it, you need first to create a WebSocket server. It won’t be on the phone, because usually the phone is only the client.
You can create a simple WebSocket server with this Perl library : https://metacpan.org/pod/Net::WebSocket::Server
Only few lines are necessary to make your WebSocket server running.
data:image/s3,"s3://crabby-images/93f14/93f144801803994b256128d9c2d5ce7d7cdf6820" alt=""
In your App.js, you can add the IP of your server in a global variable at the top of your file :
data:image/s3,"s3://crabby-images/84ffb/84ffb57b547179ac46b42ae12360c821ce9345b1" alt=""
Then in your constructor you can add the WebSocket( WS_ADRESS_SERVER_STRING ) Javascript object, so the websockets will be listen when the application is starting.
You can add the 4 events onopen, onmessage, onerror, onclose :
data:image/s3,"s3://crabby-images/29631/296314193f1c70a71f56f7aef9289210731d276a" alt=""
Now you should add ws.send() to send data inside your code or inside your UI with onPress.