<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Lean Evolution</title>
    <description>The latest articles on DEV Community by Lean Evolution (@lean_evolution_8c35e0b3d4).</description>
    <link>https://dev.to/lean_evolution_8c35e0b3d4</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1560104%2F6fef3215-564f-47aa-b4ec-56fe2df5c127.png</url>
      <title>DEV Community: Lean Evolution</title>
      <link>https://dev.to/lean_evolution_8c35e0b3d4</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/lean_evolution_8c35e0b3d4"/>
    <language>en</language>
    <item>
      <title>WebSocket Connection Issue: Works in Expo Go but Fails in Production</title>
      <dc:creator>Lean Evolution</dc:creator>
      <pubDate>Sat, 01 Jun 2024 17:15:28 +0000</pubDate>
      <link>https://dev.to/lean_evolution_8c35e0b3d4/websocket-connection-issue-works-in-expo-go-but-fails-in-production-28ne</link>
      <guid>https://dev.to/lean_evolution_8c35e0b3d4/websocket-connection-issue-works-in-expo-go-but-fails-in-production-28ne</guid>
      <description>&lt;p&gt;I'm facing an issue with my Expo React Native app where the WebSocket connection works perfectly when running in Expo Go (development mode), but fails to connect when the app is installed on a smartphone in production mode.&lt;/p&gt;

&lt;p&gt;Here are the details: The app uses WebSocket to communicate with an ESP32 device over a local Wi-Fi network, routed by the same smartphone where I run the app. In development mode using Expo Go, the WebSocket connection is stable and data is transmitted without any problems. When the app is built and installed on a smartphone (Android), the WebSocket does not connect. The smartphone is acting as the access point for the Wi-Fi network, and the ESP32 connects directly to it. The ESP32 is the Websocket server and the app connect trought the ESP32 IP and port.&lt;/p&gt;

&lt;p&gt;I've checked for any potential issues with wifi enable but couldn't pinpoint the problem.&lt;/p&gt;

&lt;p&gt;Has anyone encountered similar issues or have any insights on what might be causing the WebSocket connection to fail in production? Any help or suggestions would be greatly appreciated!&lt;/p&gt;

&lt;p&gt;app.json&lt;/p&gt;

&lt;p&gt;{&lt;br&gt;
  "expo": {&lt;br&gt;
    "name": "appLidar",&lt;br&gt;
    "slug": "appLidar",&lt;br&gt;
    "version": "1.0.0",&lt;br&gt;
    "orientation": "portrait",&lt;br&gt;
    "icon": "./assets/icon.png",&lt;br&gt;
    "userInterfaceStyle": "light",&lt;br&gt;
    "splash": {&lt;br&gt;
      "image": "./assets/splash.png",&lt;br&gt;
      "resizeMode": "contain",&lt;br&gt;
      "backgroundColor": "#ffffff"&lt;br&gt;
    },&lt;br&gt;
    "ios": {&lt;br&gt;
      "supportsTablet": true&lt;br&gt;
    },&lt;br&gt;
    "android": {&lt;br&gt;
      "permissions": ["INTERNET", "ACCESS_NETWORK_STATE"],&lt;br&gt;
      "adaptiveIcon": {&lt;br&gt;
        "foregroundImage": "./assets/adaptive-icon.png",&lt;br&gt;
        "backgroundColor": "#ffffff"&lt;br&gt;
      },&lt;br&gt;
      "package": "com.WebSilos.appLidar"&lt;br&gt;
    },&lt;br&gt;
    "web": {&lt;br&gt;
      "favicon": "./assets/favicon.png"&lt;br&gt;
    },&lt;br&gt;
    "extra": {&lt;br&gt;
      "eas": {&lt;br&gt;
        "projectId": "5f51a79e-ae14-4aeb-9de3-300395e7bd48"&lt;br&gt;
      }&lt;br&gt;
    }&lt;br&gt;
  }&lt;br&gt;
}&lt;br&gt;
app.js&lt;/p&gt;

&lt;p&gt;import { StatusBar } from "expo-status-bar";&lt;br&gt;
import { Pressable, StyleSheet, Text, View } from "react-native";&lt;br&gt;
import { useEffect, useState } from "react";&lt;/p&gt;

&lt;p&gt;let lastMsg = "Mensagem Inicial";&lt;/p&gt;

&lt;p&gt;function connectWebSocket() {&lt;br&gt;
  const ws = new WebSocket(&lt;code&gt;ws://192.168.43.12:81&lt;/code&gt;);&lt;br&gt;
  lastMsg = "Iniciando WebSocket";&lt;br&gt;
  console.log(lastMsg);&lt;/p&gt;

&lt;p&gt;ws.onopen = (event) =&amp;gt; {&lt;br&gt;
    lastMsg = "Sensor conectado!" + event.data;&lt;br&gt;
    console.log(lastMsg);&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;// connectLidar = true;
// extConnected !== undefined ? extConnected(connectLidar) : "";
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;p&gt;};&lt;/p&gt;

&lt;p&gt;ws.onmessage = async function (event) {&lt;br&gt;
    lastMsg = "Mensagem recebida: " + event.data;&lt;br&gt;
    console.log(lastMsg);&lt;br&gt;
    // const lidarData = event.data.split(",");&lt;br&gt;
    // if (lidarData[0] === "B0") {&lt;br&gt;
    //   log.push("Botao alterado: " + lidarData[1]);&lt;br&gt;
    //   if (lidarData[1] === "true") {&lt;br&gt;
    //     extStart();&lt;br&gt;
    //   }&lt;br&gt;
    // } else {&lt;br&gt;
    //   const lidarFiltered = await bufferReceive(lidarData);&lt;br&gt;
    // }&lt;br&gt;
  };&lt;/p&gt;

&lt;p&gt;ws.onclose = function (event) {&lt;br&gt;
    lastMsg = "Conexão fechada, código:" + event.code;&lt;br&gt;
    console.log(lastMsg);&lt;br&gt;
    // connectLidar = false;&lt;br&gt;
    // extConnected !== undefined ? extConnected(connectLidar) : "";&lt;br&gt;
    // // Tentar reconectar após 30 segundos&lt;br&gt;
    // setTimeout(connectWebSocket, 30000);&lt;br&gt;
  };&lt;br&gt;
}&lt;/p&gt;

&lt;p&gt;// Iniciar a conexão WebSocket&lt;br&gt;
connectWebSocket();&lt;/p&gt;

&lt;p&gt;export default function App() {&lt;br&gt;
  const [mensagem, setMensagem] = useState("Local para mensagens recebidas");&lt;/p&gt;

&lt;p&gt;const handlePress = () =&amp;gt; {&lt;br&gt;
    setMensagem(lastMsg);&lt;br&gt;
  };&lt;/p&gt;

&lt;p&gt;return (&lt;br&gt;
    &lt;br&gt;
      Open up App.js to start working on your app!&lt;br&gt;
      &lt;br&gt;
        {mensagem}&lt;br&gt;
      &lt;br&gt;
      &lt;br&gt;
    &lt;br&gt;
  );&lt;br&gt;
}&lt;/p&gt;

&lt;p&gt;const styles = StyleSheet.create({&lt;br&gt;
  container: {&lt;br&gt;
    flex: 1,&lt;br&gt;
    backgroundColor: "#fff",&lt;br&gt;
    alignItems: "center",&lt;br&gt;
    justifyContent: "center",&lt;br&gt;
  },&lt;br&gt;
});&lt;br&gt;
package.json&lt;/p&gt;

&lt;p&gt;{&lt;br&gt;
  "name": "applidar",&lt;br&gt;
  "version": "1.0.0",&lt;br&gt;
  "main": "expo/AppEntry.js",&lt;br&gt;
  "scripts": {&lt;br&gt;
    "start": "expo start",&lt;br&gt;
    "android": "expo start --android",&lt;br&gt;
    "ios": "expo start --ios",&lt;br&gt;
    "web": "expo start --web"&lt;br&gt;
  },&lt;br&gt;
  "dependencies": {&lt;br&gt;
    "expo": "~51.0.8",&lt;br&gt;
    "expo-status-bar": "~1.12.1",&lt;br&gt;
    "react": "18.2.0",&lt;br&gt;
    "react-native": "0.74.1",&lt;br&gt;
    "expo-dev-client": "~4.0.15"&lt;br&gt;
  },&lt;br&gt;
  "devDependencies": {&lt;br&gt;
    "&lt;a class="mentioned-user" href="https://dev.to/babel"&gt;@babel&lt;/a&gt;/core": "^7.20.0"&lt;br&gt;
  },&lt;br&gt;
  "private": true&lt;br&gt;
}&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
