-
Notifications
You must be signed in to change notification settings - Fork 792
Trouble Shooting
This usually means that you're using ES5, you use require('react-native-fetch-blob')
instead of import RNFetchBlob from 'react-native-fetch-blob'
. There's a very very good explanation on StackOverflow
The issue is you are using ES5 style require statements with a library written against ES6/ES2015. You have two options:
ES5:
var RNFetchBlob = require('react-native-fetch-blob').default
ES6:
import RNFetchBlob from 'react-native-fetch-blob'
by rmevans9@StackOverflow
This usually happens when the RNFetchBlob deployment target version is incorrect, it is fixed in 0.7.1
, you may upgrade your package to 0.7.1
or manually fix it by following steps
Open .xcodeproj
of your app and open the Libraries
folder in left side tree view
Find project -> RNFetchBlob, click on it
Change the deployment target to 7.0
Rebuild the project again
reference from official document
App Transport Security is a security feature, added in iOS 9, that rejects all HTTP requests that are not sent over HTTPS. This can result in HTTP traffic being blocked, including the developer React Native server.
ATS is disabled by default in projects generated using the React Native CLI in order to make development easier. You should re-enable ATS prior to building your app for production by removing the NSAllowsArbitraryLoads entry from your Info.plist file in the ios/ folder.
To learn more about how to configure ATS on your own Xcode projects, see this post on ATS.
If you're having problem when compiling IOS project, and the error looks like
ARC forbids synthesizing a property of an Objective-C ..
You should try to upgrade Xcode to version >= 7.3
or upgrade react-native-fetch-blob
to latest version, because we have already solved this problem.
see also #31
Error messages like XXX is undefined
, could not found RNFetchBlob ...
usually because the package does not properly installed, there're some closed issues about installation problems #51, #12, #30
After 0.6.2
you can access files inside app bundle by simply adding the prefix bundle-assets://
before the filename. You can also wrap the filename by fs.asset API. For example, upload a file from assets
RNFetchBlob
.fetch('POST', 'http://myupload.com/upload',
{ 'Content-Type' : 'application/octet-stream' },
RNFetchBlob.wrap(RNFetchBlob.fs.asset('my-asset.png')))
.then((resp) => { ... })
Generally you can access the file as usual once you wrap the file name by fs.asset, but keep in mind, assets files are readonly
, so you are not be able to remove, or change them.