@capacitor-community/http
Capacitor community plugin for native HTTP requests, file download/uploads, and cookie management.
Maintainer | GitHub | Social |
---|---|---|
Max Lynch | mlynch | @maxlynch |
Thomas Vidas | thomasvidas | @thomasvidas |
npm install @capacitor-community/http
npx cap sync
No configuration required for this plugin
To use the plugin while fully supporting the web version, import and use it like this:
import { Http } from '@capacitor-community/http';
// Example of a GET request
const doGet = () => {
const options = {
url: 'https://example.com/my/api',
headers: { 'X-Fake-Header': 'Max was here' },
params: { size: 'XL' },
};
const response: HttpResponse = await Http.get(options);
// or...
// const response = await Http.request({ ...options, method: 'GET' })
};
// Example of a POST request. Note: data
// can be passed as a raw JS Object (must be JSON serializable)
const doPost = () => {
const options = {
url: 'https://example.com/my/api',
headers: { 'X-Fake-Header': 'Thomas was here' },
data: { foo: 'bar', cool: true },
};
const response: HttpResponse = await Http.post(options);
// or...
// const response = await Http.request({ ...options, method: 'POST' })
};
const setCookie = async () => {
const options = {
url: 'http://example.com',
key: 'language',
value: 'en',
};
await Http.setCookie(options);
};
const deleteCookie = async () => {
const options = {
url: 'http://example.com',
key: 'language',
};
await Http.deleteCookie(options);
};
const clearCookies = async () => {
await Http.clearCookies({ url: 'http://example.com' });
};
const getCookies = async () => {
const cookies: HttpCookie[] = await Http.getCookies({
url: 'http://example.com',
});
};
const downloadFile = async () => {
const options = {
url: 'https://example.com/path/to/download.pdf',
filePath: 'document.pdf',
fileDirectory: FilesystemDirectory.Downloads,
};
// Writes to local filesystem
const response: HttpDownloadFileResult = await Http.downloadFile(options);
// Then read the file
if (response.path) {
const read = await Filesystem.readFile({
path: 'download.pdf',
directory: FilesystemDirectory.Downloads,
});
}
};
const uploadFile = async () => {
const options = {
url: 'https://example.com/path/to/upload.pdf',
name: 'myFile',
filePath: 'document.pdf',
fileDirectory: FilesystemDirectory.Downloads,
};
const response: HttpUploadFileResult = await Http.uploadFile();
};
Coming soon
As of iOS 14, you cannot use 3rd party cookies by default. There
is an open issue on the Capacitor Core repo on properly patching
in cookies on iOS. For now, you must specify a domain of for the
cookie you are saving to properly save and send them via requests.
You can also add the following lines to your
Info.plist
file to get better support for cookies on
iOS. You can add up to 10 domains.
<key>WKAppBoundDomains</key>
<array>
<string>www.mydomain.com</string>
<string>api.mydomain.com</string>
<string>www.myothercooldomain.com</string>
</array>
Thanks goes to these wonderful people (emoji key):
Daniel Sogl 📖 |
Priyank Patel 💻 |
Max Lynch 💻 |
Falk Schieber 👀 |
Andy Sousa 💻 |
Thomas Vidas 💻 🚧 |
This project follows the all-contributors specification. Contributions of any kind welcome!
Generated using TypeDoc