CookieManager 管理cookie相关的API

API兼容性:
QRN:v1.0.0-RC
iOS:80011115
Android:60001130

CookieManager可以用来获取、设置和删除指定的cookie,支持的api如下:

引入

import { CookieManager } from 'qunar-react-native';

数据结构

Cookie = {
    key: string, //cookie的key值
    value: string, //cookie对应该key的value值
    domain:string, //cookie的Domain值
    path:string, //cookie的Path值
    expires:string, //cookie的Expires值
    secure:string, //是否使用secure的bool值
    httpOnly:string, //是否httpOnly的bool值
}

API

CookieManager.getCookieForKey ( key:string, url: string, callBack: function, errCallBack: function)
根据key、和url获取指定的Cookie
获取成功则callBack返回Cookie,否则调用errCallBack

CookieManager.setCookie ( cookie: Cookie, callBack: function)
设置cookie
如果设置完成调用callBack

CookieManager.removeCookieForKey ( key: string, url: string, callBack: function)
根据key和url移除cookie
移除完成调用callBack

CookieManager.removeCookie ( cookie: Cookie, callBack: function)
移除指定的cookie, 根据cookie的key、domain和path判断需要删除的cookie
移除完成调用callBack

CookieManager.syncCookie (callBack: function)
API 版本至少 QRN 1.4.0
同步cookie, 同步完成后调用 callBack。一般不需要调用, 对cookie同步实时性要求高的时候使用。

示例

import {CookieManager, Alert} from 'qunar-react-native';

//获取对应key和url的cookie信息,第一个参数为key,第二个参数为url  
CookieManager.getCookieForKey('QN1', 'http://wap.qunar.com',
    (cookie) => {
    //获取cookie成功
        Alert.alert(JSON.stringify(cookie));
    }, (error) => {
    //获取cookie失败
        Alert.alert(error.message);
    });


//设置cookie,cookie必须包含key、domain和value
var cookie = {key: 'QN1',domain: '.qunar.com',value: 'valueResult'};
CookieManager.setCookie(cookie,()=> {
    Alert.alert('设置成功');
});


//移除特定key和url的cookie,第一个参数为key,第二个参数为url
CookieManager.removeCookieForKey('QN1','http://.qunar.com',()=> {
    Alert.alert('清除成功');
});

//移除指定的cookie, 根据cookie的key、domain和path判断需要删除的cookie
var cookie2 = {key: 'QN1',domain: '.qunar.com',path: '/'};
CookieManager.removeCookie(cookie2,()=> {
    Alert.alert('删除成功');
});

// 同步cookie, 一般不需要调用, 对cookie同步实时性要求高的时候使用。
// API 版本至少 QRN 1.4.0 版本
CookieManager.syncCookie(()=>{
    //同步完成
})