React Native fetch() Network Request Failed

React Native fetch() Network Request Failed



When I create a brand new project using react-native init (RN version 0.29.1) and put a fetch in the render method to the public facebook demo movie API, it throws a Network Request Failed. There is a very useless stack trace and I can't debug network requests in the chrome console. Here is the fetch I'm sending:


react-native init


Network Request Failed


fetch('http://facebook.github.io/react-native/movies.json')
.then((response) => response.json())
.then((responseJson) =>
return responseJson.movies;
)
.catch((error) =>
console.error(error);
);





I'm not sure. I'm using the iOS simulator and I thought it used my computer's internet connection
– Alek Hurst
Jul 17 '16 at 8:00





Try loading the simulator manually and opening the url in safari
– FuzzyTree
Jul 17 '16 at 22:32





http -> https (if possible) will most likely fix your issue
– Nick Zuber
Oct 12 '16 at 0:20


http


https




10 Answers
10



The problem here is that iOS does not allow HTTP requests by default, only HTTPS. If you want to enable HTTP requests add this to your info.plist:


info.plist


<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>





This answer worked for me. For others new to React Native, this file (info.plist) can also be edited through xcode: stackoverflow.com/a/38219454/1299792
– Marklar
Feb 28 '17 at 22:26





what about android? I am facing same issue in android as well.
– Vijay Sharma
May 19 '17 at 9:45





Exactly. Anyone have the answer for android?
– Zach Cook
Aug 31 '17 at 6:15





when i put that on ios/build/info.plist and run: react-native run-ios The ios/build/info.plist is overwritten and quit my changes What should i do ?
– Jorge Wander Santana Ureña
Oct 4 '17 at 12:22





@JorgeWanderSantanaUreña modify [your_project_folder_name]/ios/[your_project_folder_name]/In‌​fo.plist
– kgosse
Oct 31 '17 at 0:15



Not recommended to allow all domains for http.
Make an exception for just the necessary domains.



Source: Configuring App Transport Security Exceptions in iOS 9 and OSX 10.11



Add the following to the info.plist file of your app:


<key>NSAppTransportSecurity</key>
<dict>
<key>NSExceptionDomains</key>
<dict>
<key>yourserver.com</key>
<dict>
<!--Include to allow subdomains-->
<key>NSIncludesSubdomains</key>
<true/>
<!--Include to allow HTTP requests-->
<key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
<true/>
<!--Include to specify minimum TLS version-->
<key>NSTemporaryExceptionMinimumTLSVersion</key>
<string>TLSv1.1</string>
</dict>
</dict>
</dict>





what about android?
– arisalexis
Nov 2 '16 at 11:42





There seems to be multiple info.plist files in multiple directories in my React Native app. Any idea which folder contains the correct file to change?
– Marklar
Feb 28 '17 at 6:27





@Marklar [your_project_folder_name]/ios/[your_project_folder_name]/Info.plist
– Stich
Apr 5 '17 at 12:09





stackoverflow.com/a/40299837/5837066
– Aman Agarwal
Jul 3 at 17:37



React Native Docs gives the answer for this.



Apple has blocked implicit cleartext HTTP resource loading. So we need to add the following our project's Info.plist (or equivalent) file.


<key>NSExceptionDomains</key>
<dict>
<key>localhost</key>
<dict>
<key>NSTemporaryExceptionAllowsInsecureHTTPLoads</key>
<true/>
</dict>
</dict>



React Native Docs -> Integration With Existing Apps -> App Transport Security



I was using localhost for the address, which was obviously wrong. After replacing it with the IP address of the server (in the network that emulator is), it worked perfectly.


localhost



Edit



In Android Emulator, the address of the development machine is 10.0.2.2. More explanation here


10.0.2.2





Thank you. Probably the only response I've seen that works for android. Used my networks IP address and it works. eg http://<Network IP emulator connects to>:<port where API is served>/api/tasks
– Brandon Benefield
Jul 19 at 7:35


http://<Network IP emulator connects to>:<port where API is served>/api/tasks





Don't forget the "http://" or else it won't work ... was wondering why it would work on postman but not with fetch
– Moucheg
Jul 31 at 20:48



The problem may be in server configuration.



Android 7.0 has a bug described here. Workaround proposed by Vicky Chijwani:



Configure your server to use the elliptic curve prime256v1. For
example, in Nginx 1.10 you do this by setting ssl_ecdh_curve
prime256v1;



For Android, you may have missed to add permission in AndroidManifest.xml
Need to add the following permission.


<uses-permission android:name="android.permission.INTERNET" />





I already do have that even though I am getting that error, is there any other workaround?
– masud_moni
Apr 22 at 5:30



I have similar problem.
In my case requests to localhost was working and suddenly stopped.
It turn out that the problem was that I was turn off my wifi on my android phone.



I was having this problem for Android-



URL- localhost/authToken.json - didn't work :(



URL- 10.106.105.103/authToken.json - didn't work :(



URL- http://10.106.105.103/authToken.json - worked :) :D



Note- Use ifconfig on Linux or ipconfig on Windows to find machine IpAddress


ifconfig


ipconfig



Just you have Changes in Fetch....


fetch('http://facebook.github.io/react-native/movies.json')
.then((response) => response.json())
.then((responseJson) =>
/*return responseJson.movies; */
alert("result:"+JSON.stringify(responseJson))
this.setState(
dataSource:this.state.dataSource.cloneWithRows(responseJson)
)
).catch((error) =>
console.error(error);
);



Example:


return fetch('http://<your ip>')
.then((response) => response.json())
.then((responseJson) =>
console.log(responseJson)
)
.catch((error) =>
console.error(error);
);






By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.

Popular posts from this blog

𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌