|
@@ -1,9 +1,7 @@
|
1
|
|
-# react-native-fetch-blob [data:image/s3,"s3://crabby-images/f283e/f283e4b0f4ef90077abd92a68b27bf8f743c9143" alt="npm version"](https://badge.fury.io/js/react-native-fetch-blob) data:image/s3,"s3://crabby-images/d41ff/d41ff8f0ff3048ceca09e4283c6498d6dc65bf98" alt="" data:image/s3,"s3://crabby-images/98a62/98a62e8b97e39572a0bcc8e937f6bb23aee30a3e" alt=""
|
|
1
|
+# react-native-fetch-blob [data:image/s3,"s3://crabby-images/f3dd7/f3dd70dbddaffaf67c3bd982c77e74852edca67e" alt="npm version"](https://badge.fury.io/js/react-native-fetch-blob) data:image/s3,"s3://crabby-images/d41ff/d41ff8f0ff3048ceca09e4283c6498d6dc65bf98" alt="" data:image/s3,"s3://crabby-images/98a62/98a62e8b97e39572a0bcc8e937f6bb23aee30a3e" alt=""
|
2
|
2
|
|
3
|
3
|
A module provides upload, download, and files access API. Supports file stream read/write for process large files.
|
4
|
4
|
|
5
|
|
-**[Please visit our Github for updated document](https://github.com/wkh237/react-native-fetch-blob)**
|
6
|
|
-
|
7
|
5
|
**Why do we need this**
|
8
|
6
|
|
9
|
7
|
At this moment, React Native does not support `Blob` object yet, so if you're going to send/receive binary data via `fetch` API, that might not work as you expect. See [[fetch] Does fetch with blob() marshal data across the bridge?](https://github.com/facebook/react-native/issues/854).
|
|
@@ -28,6 +26,7 @@ This update is `backward-compatible` generally you don't have to change existing
|
28
|
26
|
* [File access](#user-content-file-access)
|
29
|
27
|
* [File stream](#user-content-file-stream)
|
30
|
28
|
* [Manage cached files](#user-content-manage-cached-files)
|
|
29
|
+ * [Self-Signed SSL Server](#user-content-selfsigned-ssl-server)
|
31
|
30
|
* [API](#user-content-api)
|
32
|
31
|
* [config](#user-content-configoptionsrnfetchblobconfigfetch)
|
33
|
32
|
* [fetch](#user-content-fetchmethod-url-headers-bodypromisefetchblobresponse)
|
|
@@ -484,6 +483,20 @@ You can also grouping requests by using `session` API, and use `dispose` to remo
|
484
|
483
|
|
485
|
484
|
```
|
486
|
485
|
|
|
486
|
+#### Self-Signed SSL Server
|
|
487
|
+
|
|
488
|
+By default, react-native-fetch-blob does NOT allow connection to unknown certification provider since it's dangerous. If you're going to connect a server with self-signed certification, add `trusty` to `config`. This function is available for version >= `0.5.3`
|
|
489
|
+
|
|
490
|
+```js
|
|
491
|
+RNFetchBlob.config({
|
|
492
|
+ trusty : true
|
|
493
|
+})
|
|
494
|
+.then('GET', 'https://mysite.com')
|
|
495
|
+.then((resp) => {
|
|
496
|
+ // ...
|
|
497
|
+})
|
|
498
|
+```
|
|
499
|
+
|
487
|
500
|
---
|
488
|
501
|
|
489
|
502
|
## API
|
|
@@ -759,10 +772,14 @@ Connect `Media Scanner` and scan the file. see [Android Media Scanner, and Downl
|
759
|
772
|
|
760
|
773
|
A set of configurations that will be injected into a `fetch` method, with the following properties.
|
761
|
774
|
|
|
775
|
+#### trusty:boolean
|
|
776
|
+ `0.5.3`
|
|
777
|
+ Set this property to `true` will allow the request create connection with server have self-signed SSL certification. This is not recommended to use in production.
|
|
778
|
+
|
762
|
779
|
#### fileCache:boolean
|
763
|
780
|
Set this property to `true` will makes response data of the `fetch` stored in a temp file, by default the temp file will stored in App's own root folder with file name template `RNFetchBlob_tmp${timestamp}`.
|
764
|
781
|
#### appendExt:string
|
765
|
|
- Set this propery to change temp file extension that created by `fetch` response data.
|
|
782
|
+ Set this property to change temp file extension that created by `fetch` response data.
|
766
|
783
|
#### path:string
|
767
|
784
|
When this property has value, `fetch` API will try to store response data in the path ignoring `fileCache` and `appendExt` property.
|
768
|
785
|
#### addAndroidDownloads:object (Android only)
|
|
@@ -815,7 +832,7 @@ Statistic data of a file, see the following sample object.
|
815
|
832
|
|
816
|
833
|
### RNFetchBlobSession
|
817
|
834
|
|
818
|
|
-A `session` is an object that helps you manage files. It simply main a list of file path and let you use `dispose()`to delete files in this session once and for all.
|
|
835
|
+A `session` is an object that helps you manage files. It simply maintains a list of file path and let you use `dispose()`to delete files in this session once and for all.
|
819
|
836
|
|
820
|
837
|
#### add(path:string):RNFetchBlobSession
|
821
|
838
|
Add a file path to this session.
|
|
@@ -830,6 +847,7 @@ A `session` is an object that helps you manage files. It simply main a list of f
|
830
|
847
|
|
831
|
848
|
| Version | |
|
832
|
849
|
|---|---|
|
|
850
|
+| 0.5.3 | Add API for access untrusted SSL server |
|
833
|
851
|
| 0.5.2 | Fix improper url params bug [#26](https://github.com/wkh237/react-native-fetch-blob/issues/26) and change IOS HTTP implementation from NSURLConnection to NSURLSession |
|
834
|
852
|
| 0.5.0 | Upload/download with direct access to file storage, and also added file access APIs |
|
835
|
853
|
| 0.4.2 | Supports upload/download progress |
|
|
@@ -849,5 +867,5 @@ A `session` is an object that helps you manage files. It simply main a list of f
|
849
|
867
|
|
850
|
868
|
### Development
|
851
|
869
|
|
852
|
|
-If you're interested in hacking this module, check our [development guide](https://github.com/wkh237/react-native-fetch-blob/wiki/Development-Guide), there might be some helpful information.
|
|
870
|
+If you're interested in hacking this module, check our [development guide](https://github.com/wkh237/react-native-fetch-blob/wiki/Home), there might be some helpful information.
|
853
|
871
|
Please feel free to make a PR or file an issue.
|