Невозможно соединиться с удаленным отладчиком


149

Я использую React.JS, и когда я делаю react-native run-android(с подключенным устройством), я вижу пустую страницу. Когда я встряхиваю устройство и выбираю Debug JS Remotelyиз списка опций, я вижу следующий экран.

введите описание изображения здесь

FYI:

OS: Ubuntu 16.04
Node version is: v4.6.2
java version "1.8.0_111"
react": "15.4.1
react-native": "0.38.0

1
На Android вам нужно запустить в отдельном окне, react-native startчтобы запустить сервер.
Александар Попович

Как насчет изменения этого: compile "com.facebook.react:react-native:+"в разделе компиляции.
Сатана Пандея

Вы должны включить "отладку" в меню разработчика
UA_

Ответы:


280

В моем случае проблема заключалась в том, что эмулятор делал запрос:

http://10.0.2.2:8081/debugger-ui

вместо того:

http://localhost:8081/debugger-ui и запрос не удался.

Чтобы решить эту проблему: Перед включением удаленной отладки на вашем эмуляторе откройте http://localhost:8081/debugger-uiв Chrome. Затем включите удаленную отладку и вернитесь на страницу Chrome, где вы должны увидеть журналы консоли.


1
работал для меня - спасибо! Вы нашли способ установить его, чтобы всегда пытаться подключиться к localhost, чтобы избежать необходимости открывать вкладку Chrome в первую очередь?
izikandrw

26
Вы можете зайти в настройки Dev (Ctrl + M) на вашем эмуляторе и изменить сервер отладки на localhost: 8081.
ДэнниМоше

Последний абзац - единственное, что сработало для меня.
Педро Отеро

3
Спасибо. Как это установить на 10.0.2.2 в первую очередь?
Чарлиб

3
Запрос к «localhost», сделанный из вашего эмулятора, попытается получить доступ к порту обратной петли на эмуляторе, а не на вашем ПК (вы хотите петлю вашего компьютера). Чтобы решить эту проблему, Android создает псевдоним 10.0.2.2, чтобы позволить вам получить доступ к службам, запущенным на вашем ПК (см. Документацию на developer.android.com/studio/run/emulator-networking ). Относительно того, почему запрос терпит неудачу, я не уверен, но кажется, что это задокументированная проблема с реакцией / android, см. Github.com/facebook/react-native/issues/17970 .
ДэнниМоше

181

Решил вопрос следующим образом:

  • Нажмите Cmd + Mна экране эмулятора
  • Перейти к Dev settings > Debug server host & port for device
  • Устанавливать localhost:8081
  • Перезапустите приложение Android: react-native run-android

Отладчик подключен сейчас!


Для тех из вас, у кого есть проблема с неработающей кнопкой CMD + M, я использовал «./adb shell input keyevent 82» в оболочке, где расположен adb, чтобы вызвать ее. Клавиши быстрого доступа начали работать после этого!
Джефф Л

Вы, сэр, кровавая легенда. x
NewbieAid

Теперь он просто пытается подключиться к удаленному отладчику ... на вечность
Fakebounce

44

Я решил это сделать, adb reverse tcp:8081 tcp:8081а затем reloadна моем телефоне.


36

В моем случае при выборе Debug JS Remote запускался Chrome, но не подключался к устройству Android. Обычно на новой вкладке / окне Chrome URL-адрес отладки предварительно заполняется в адресной строке, но в этом случае адресная строка была пустой. По истечении времени ожидания отображается сообщение об ошибке «Не удается подключиться к удаленному отладчику». Я исправил это с помощью следующей процедуры:

  • Бегать adb reverse tcp:8081 tcp:8081
  • Вставьте http://localhost:8081/debugger-uiв поле адреса моего браузера Chrome. Вы должны увидеть обычный экран отладки, но ваше приложение все равно не будет подключено.

Это должно решить проблему. Если нет, вам может потребоваться выполнить следующие дополнительные действия:

  • Закройте и удалите приложение с вашего устройства Android
  • Переустановите приложение с react-native run-android
  • Включите удаленную отладку в вашем приложении.
  • Ваше приложение должно быть подключено к отладчику.

2
Том ... спасибо! Перед этим я установил свой IP-адрес («Настройки Dev» -> «Сервер отладки для устройства») xxxx: 8081
atreeon

11

У меня была похожая проблема, которая привела меня к этому вопросу. В моем браузере отладчик я получаю это сообщение об ошибке:

Доступ к выборке по адресу http: // localhost: 8081 / index.delta? Platform = android & dev = true & minify = false 'from origin' http://127.0.0.1:8081 'заблокирован политикой CORS: No' Access-Control Заголовок -Allow-Origin 'присутствует на запрашиваемом ресурсе. Если непрозрачный ответ отвечает вашим потребностям, установите режим запроса «no-cors», чтобы получить ресурс с отключенным CORS.

Мне потребовалось некоторое время, чтобы понять, что я использовал 127.0.0.1:8081вместо localhost:8081отладчика.

Чтобы это исправить, мне просто пришлось сменить Chrome на:

http://127.0.0.1:8081/debugger-ui/

в

http://localhost:8081/debugger-ui/

1
на самом деле для меня все было наоборот. Но на самом деле «localhost» обычно эквивалентен 127.0.0.1. Это зависит от того, что установлено для адреса как localhost. Всегда лучше быть
точным,

2

Убедитесь, что сервер узла, предоставляющий пакет, работает в фоновом режиме. Для запуска запуска сервера используйте npm startили react-native startи оставьте вкладку открытой во время разработки


1
Все еще не работает. Ни один из терминалов не возвращает мне ошибок
разозлился


Нет, я не использую прокси-сервер
spunk

2

Мой случай, когда я нажимаю включить удаленную отладку JS, он запускает Chrome, но не может подключиться к нему.

Я пытался бежать:

adb reverse tcp:8081 tcp:8081 

, но не работает.

Я полностью удалил свой хром и установил новый. И это работает.


1
  1. реактивный запуск - сброс кеша в одной вкладке и реактивный запуск андроида в другой
  2. adb reverse tcp: 8081 tcp: 8081 (чтобы вы могли добавить его в свои скрипты и просто запустить yarn, запустите adb-reverse )
  3. Если вы используете Android, вместо встряхивания телефона отличный совет - запускать команды adb.

Таким образом, вы можете запустить:

  • ввод ключа оболочки adb 82 ( опция меню )
  • ввод ключа оболочки adb 46 46 ( перезагрузка )

1

Другие ответы здесь упустили один важный шаг для меня. В AndroidManifest.xml мне нужно было добавить useCleartextTraffic:

    <application
      ...
      android:usesCleartextTraffic="true">

Вы, вероятно, не хотите оставлять это в производственной версии своего приложения, если только вы не хотите поддерживать небезопасные запросы http.

После того, как я добавил это в свой AndroidManifest.xml, я последовал ответу Тома Аранда, и эмулятор наконец смог подключиться к отладчику.


0

Я сделал ответ @sajib s и использовал этот скрипт для перенаправления портов:

#!/usr/bin/env bash

# packager
adb reverse tcp:8081 tcp:8081
adb -d reverse tcp:8081 tcp:8081
adb -e reverse tcp:8081 tcp:8081

echo "🚧 React Native Packager Redirected 🚧"

0

удалите приложение, а затем запустите реагирующую версию run-android. затем нажмите «Отладка» в «Chrome» и замените http: // localhost: 8081 / debugger-ui / , «завершить запуск». если вам все еще не удалось, попробуйте еще раз


0

Включая все впечатляющие ответы специально разработчики Ribamar Santos предоставленные , если у вас не получилось, вы должны проверить что-то более сложное!

Что-то вроде Airplane modeвашего (эмулированного) телефона! Или your network status of Emulator( Data status and Voice status on Cellular tab of Emulator configuration), которым можно манипулировать, чтобы не выражать сеть! для некоторых нужд эмуляции!

Я решил эту проблему с помощью этого трюка! Это была немного захватывающая отладка, чтобы найти эту дыру!



Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.