• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    ReactNative踩坑之配置調試端口的解決方法

    來源:懂視網 責編:小采 時間:2020-11-27 22:33:42
    文檔

    ReactNative踩坑之配置調試端口的解決方法

    ReactNative踩坑之配置調試端口的解決方法:本文介紹了ReactNative踩坑之配置調試端口的解決方法,分享大家,順便也給自己留個筆記 問題是這樣的,由于公司的機器安裝了安全軟件,http://localhost:8081被占用了。(windows上配置環境真不易,最后一步還是被公司環境坑了) 所以導致按照教程配置完環境
    推薦度:
    導讀ReactNative踩坑之配置調試端口的解決方法:本文介紹了ReactNative踩坑之配置調試端口的解決方法,分享大家,順便也給自己留個筆記 問題是這樣的,由于公司的機器安裝了安全軟件,http://localhost:8081被占用了。(windows上配置環境真不易,最后一步還是被公司環境坑了) 所以導致按照教程配置完環境

    本文介紹了ReactNative踩坑之配置調試端口的解決方法,分享大家,順便也給自己留個筆記

    問題是這樣的,由于公司的機器安裝了安全軟件,http://localhost:8081被占用了。(windows上配置環境真不易,最后一步還是被公司環境坑了)

    所以導致按照教程配置完環境最后到真機上還是刷不出來界面

    那么我們就這么放棄了嗎?當然不,不然就白忙活了

    分析問題:端口被占用,那我們換一個端口不就行啦,于是乎各種查閱資料,發現PackageManager(包管理服務)在啟動的時候是可以配置端口的.如下命令

    react-native start --port 18081

    這樣Launch起來的包管理服務就在端口18081上了,在Chrome上敲localhost:18081神奇的顯示了ReactNative的相關界面,說明正常了。

    接著在真機上需要敲這個命令

    adb reverse tcp:18081 tcp:18081

    這個命令會將手機的調試端口設置成與包管理服務一致的端口18081

    然后我在真機上跑了一遍程序,結果還是顯示不出來。莫名的傷感有沒有

    在各種找不到資料的情況下,開始翻看ReactAndroid源碼,經過分析最后找到這么一段關鍵的代碼

    public String getDebugServerHost() {
    // Check host setting first. If empty try to detect emulator type and use default
    // hostname for those
    String hostFromSettings = mPreferences.getString(PREFS_DEBUG_SERVER_HOST_KEY, null);
    
    if (!TextUtils.isEmpty(hostFromSettings)) {
     return Assertions.assertNotNull(hostFromSettings);
    }
    
    String host = AndroidInfoHelpers.getServerHost();
    
    if (host.equals(AndroidInfoHelpers.DEVICE_LOCALHOST)) {
     FLog.w(
     TAG,
     "You seem to be running on device. Run 'adb reverse tcp:8081 tcp:8081' " +
     "to forward the debug server's port to the device.");
    }
    
    return host;
    }
    
    

    好家伙,原來是從SharedPreference中先讀了PREFS_DEBUG_SERVER_HOST_KEY這個值,如果為空則用AndroidInfoHelpers.getServerHost()這個函數返回值(也就是loacalhost:8081)

    那么解決辦法就浮出水面了,只需要在Application初始化的時候講這個值設置成我們自定義的就好了,類似

    SharedPreferences mPreferences = PreferenceManager.getDefaultSharedPreferences(applicationContext);
    mPreferences.put("debug_http_host", "localhost:18081");

    這段代碼最好寫在SoLoader.init(this, /* native exopackage */ false);調用之前,因為在windows上remote debug js的時候如果不寫在前面似乎調試不起效果(調試的地址端口也變成了18081了)

    寫在最后的話,在找不到資料解決問題的時候,可以開始擼起袖子看代碼了!!!

    聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    ReactNative踩坑之配置調試端口的解決方法

    ReactNative踩坑之配置調試端口的解決方法:本文介紹了ReactNative踩坑之配置調試端口的解決方法,分享大家,順便也給自己留個筆記 問題是這樣的,由于公司的機器安裝了安全軟件,http://localhost:8081被占用了。(windows上配置環境真不易,最后一步還是被公司環境坑了) 所以導致按照教程配置完環境
    推薦度:
    標簽: 方法 端口的 React
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 999成人精品视频在线| 2024国产精品极品色在线| 亚洲av永久无码精品秋霞电影影院 | 精品视频第一页| 亚洲国产精品无码av| 久久久久九国产精品| 国产91精品一区二区麻豆亚洲| 久久精品国产精品亚洲毛片| 精品久久国产一区二区三区香蕉| 久久国产精品一区二区| 国产精品99久久免费观看| 亚洲av永久无码精品漫画| 色婷婷久久久SWAG精品| 国产亚洲精品精品国产亚洲综合| 91精品国产福利在线观看麻豆| 国产国拍亚洲精品mv在线观看| 亚洲AV无码国产精品麻豆天美| 色偷偷88欧美精品久久久| 麻豆国产高清精品国在线| 国产午夜亚洲精品理论片不卡| 成人国产精品一区二区视频| 91精品久久久久久无码| 国产精品久久久久久一区二区三区| 久久精品国产亚洲av影院| 久久精品国产亚洲AV无码麻豆 | 久久久久99精品成人片| 国产乱人伦偷精品视频不卡| mm1313亚洲国产精品无码试看| 中文字幕亚洲精品资源网| 久久99国产精品一区二区| 国产精品欧美亚洲韩国日本不卡| 国产精品禁18久久久夂久| 91精品国产91久久综合| 99久久免费国产精品热| 国产成人精品日本亚洲网址| 国产精品高清视亚洲精品| 欧美精品1区2区| 99精品国产一区二区| 精品国产国产综合精品| 久久久精品久久久久久| 欧美成人精品第一区二区三区 |