포트 포워딩으로 로컬 서버 및 Chrome 인스턴스에 액세스

Meggin Kearney
Meggin Kearney
Sofia Emelianova
Sofia Emelianova

포트 전달을 사용하여 다음 작업을 할 수 있습니다.

  • 케이스 1 다른 Chrome 인스턴스에서 열린 탭을 디버그합니다.
  • 케이스 2. 개발용 컴퓨터 웹 서버에서 사이트를 호스팅한 다음 USB 케이블을 통해 Android 기기에서 콘텐츠에 액세스합니다.

케이스 2에서는 Android 기기의 수신 대기 TCP 포트를 통해 포트 전달이 작동하며, 이 포트는 개발용 컴퓨터의 TCP 포트에 매핑됩니다. 포트 간 트래픽은 Android 기기와 개발용 컴퓨터 사이에 USB 연결을 통해 이동하므로 연결은 네트워크 구성에 의존하지 않습니다.

또한 웹 서버가 맞춤 도메인을 사용하는 경우 맞춤 도메인 매핑을 사용하여 해당 도메인의 콘텐츠에 액세스하도록 Android 기기를 설정할 수 있습니다.

포트 전달 설정

케이스에 따라 다음 단계를 따르세요.

케이스 1: 다른 Chrome 인스턴스로 포트 전달 설정

  1. --remote-debugging-port=PORT 매개변수를 사용하여 다른 Chrome 인스턴스를 실행합니다. 예를 들면 다음과 같습니다.

    MacOS

    open -a "Google Chrome" --args --remote-debugging-port=PORT
    

    Windows

    start chrome --remote-debugging-port=PORT
    

    Linux

    google-chrome --remote-debugging-port=PORT
    
  2. 디버깅 중인 Chrome 인스턴스에서 다음을 실행합니다.

    1. chrome://inspect/#devices를 엽니다.
    2. 체크박스입니다. 네트워크 타겟 검색이 선택되어 있는지 확인합니다.
    3. 체크박스 옆의 구성을 클릭합니다.
    4. 타겟 검색 설정localhost:PORT을 입력하고 체크박스입니다. 포트 전달 사용 설정을 선택한 다음 완료를 클릭합니다.

      타겟 검색 설정 창

    5. 기기로 돌아가면 새 원격 대상이 표시됩니다. 디버그하려는 탭 옆에 있는 검사를 클릭합니다.

      원격 대상의 탭 옆에 있는 검사 링크

  3. 기기 모드의 새 DevTools 창이 열립니다. 상단의 주소 표시줄에 디버그하려는 웹사이트의 주소를 입력할 수 있습니다.

    기기 모드의 DevTools

  4. 주소 표시줄 옆에서 입력 방법을 전환할 수 있습니다.

케이스 2: Android 기기에서 USB를 통해 포트 전달 설정하기

  1. 개발 머신과 Android 기기 간에 원격 디버깅을 설정합니다. 완료하면 목록에 Android 기기가 표시됩니다.

    목록에 있는 Android 기기

  2. 체크박스입니다. USB 기기 검색이 선택되어 있는지 확인합니다.

  3. 체크박스 옆에 있는 포트 전달을 클릭합니다.

  4. 포트 전달 설정에서 기본적으로 localhost:8080가 설정됩니다. 포트 전달 사용 설정을 선택합니다.

    포트 전달 설정.

  5. 다른 포트를 설정하려면 다음 단계를 따르세요. 그렇지 않으면 단계를 건너뛰고 완료를 클릭합니다.

  6. 왼쪽의 포트 텍스트 필드에 Android 기기에서 사이트에 액세스할 포트 번호를 입력합니다. 예를 들어 localhost:5000에서 사이트에 액세스하려면 5000을 입력합니다.

  7. 오른쪽의 IP 주소 및 포트 텍스트 필드에 개발 머신의 웹 서버에서 사이트가 실행 중인 IP 주소 또는 호스트 이름과 포트 번호를 입력합니다. 예를 들어 사이트가 localhost:5000에서 실행 중인 경우 localhost:5000을 입력합니다.

  8. 완료를 클릭합니다.

이제 포트 전달이 설정되었습니다. 기기 이름 옆과 상단에 포트 전달 상태 표시기가 표시됩니다.

포트 전달 상태입니다.

콘텐츠를 보려면 Android 기기에서 Chrome을 열고 Device port 필드에서 지정한 localhost 포트로 이동합니다. 예를 들어 해당 필드에 5000을 입력하면 localhost:5000으로 이동합니다.

맞춤 로컬 도메인에 매핑

사용자설정 도메인 매핑을 사용하면 사용자설정 도메인을 사용 중인 개발용 컴퓨터의 웹 서버에서 Android 기기의 콘텐츠를 볼 수 있습니다.

예를 들어 사이트에서 허용 목록 도메인 chrome.devtools에서만 작동하는 서드 파티 JavaScript 라이브러리를 사용하는 경우를 가정해 보겠습니다. 따라서 개발용 컴퓨터의 hosts 파일에 이 도메인을 localhost (즉, 127.0.0.1 chrome.devtools)에 매핑할 항목을 만듭니다. 사용자설정 도메인 매핑 및 포트 전달을 설정한 후에는 Android 기기에서 URL chrome.devtools로 사이트를 볼 수 있습니다.

포트 전달을 프록시 서버로 설정

커스텀 도메인을 매핑하려면 개발 머신에서 프록시 서버를 실행해야 합니다. 프록시 서버의 예로는 Charles, Squid, Fiddler가 있습니다.

포트 전달을 프록시로 설정하려면 다음 단계를 따르세요.

  1. 프록시 서버를 실행하고 프록시 서버가 사용 중인 포트를 확인합니다.

  2. Android 기기에 포트 전달을 설정합니다. 로컬 주소 필드에 localhost:와 프록시 서버가 실행 중인 포트를 차례로 입력합니다. 예를 들어 포트 8000에서 실행 중인 경우 localhost:8000을 입력합니다. device port 필드에 Android 기기가 수신할 번호(예: 3333)를 입력합니다.

기기에 프록시 설정 구성

이제 프록시 서버와 통신할 Android 기기를 구성해야 합니다.

  1. Android 기기에서 설정 > Wi-Fi로 이동합니다.
  2. 연결된 네트워크의 이름을 길게 누릅니다.

  3. 네트워크 수정을 탭합니다.

  4. 고급 옵션을 탭합니다. 프록시 설정이 표시됩니다.

  5. 프록시 메뉴를 탭하고 수동을 선택합니다.

  6. 프록시 호스트 이름 필드에 localhost을 입력합니다.

  7. 프록시 포트 필드에 이전 섹션의 기기 포트에 입력한 포트 번호를 입력합니다.

  8. 저장을 탭합니다.

이렇게 설정하면 기기가 모든 요청을 개발 머신의 프록시로 전달합니다. 프록시가 기기를 대신하여 요청하므로 맞춤설정된 로컬 도메인에 대한 요청이 적절히 처리됩니다.

이제 개발용 컴퓨터에서와 마찬가지로 Android 기기에서 사용자설정 도메인에 액세스할 수 있습니다.

웹 서버가 비표준 포트로 실행 중인 경우 Android 기기에서 콘텐츠를 요청할 때 포트를 지정해야 합니다. 예를 들어 웹 서버가 포트 7331에서 사용자설정 도메인 chrome.devtools를 사용 중인 경우 Android 기기에서 사이트를 볼 때 URL chrome.devtools:7331을 사용해야 합니다.