cookie_jar 1.0.0 cookie_jar: ^1.0.0 copied to clipboard
A cookie manager for http requests in Dart, by which you can deal with the complex cookie policy and persist cookies easily.
CookieJar #
A cookie manager for http requests in Dart, by which you can deal with the complex cookie policy and persist cookies easily.
Add dependency #
dependencies:
dio: ^0.0.2
Usage #
A simple usage example:
import 'package:cookie_jar/cookie_jar.dart';
void main() async {
List<Cookie> cookies = [new Cookie("name", "wendux"),new Cookie("location", "china")];
var cj = new CookieJar();
//Save cookies
cj.saveFromResponse(Uri.parse("https://www.baidu.com/"), cookies);
//Get cookies
List<Cookie> results = cj.loadForRequest(Uri.parse("https://www.baidu.com/xx"));
print(results);
}
Classes #
SerializableCookie
#
This class is a wrapper for Cookie
class. Because the Cookie
class doesn't support Json serialization, for the sake of persistence, we use this class instead of it.
CookieJar
#
CookieJar
is a default cookie manager which implements the standard cookie policy declared in RFC. CookieJar saves the cookies in RAM, so if the application exit, all cookies will be cleared. A example as follow:
var cj= new CookieJar();
PersistCookieJar
#
PersistCookieJar
is a cookie manager which implements the standard cookie policy declared in RFC. PersistCookieJar
persists the cookies in files, so if the application exit, the cookies always exist unless call delete
explicitly. A example as follows:
// Cookie files will be saved in "./cookies"
var cj=new PersistCookieJar(
dir:"./cookies",
ignoreExpires:true, //save/load even cookies that have expired.
);
Note: In Flutter, File system is different from PC, you can use path_provider package to get the path :
// API `getTemporaryDirectory` is from "path_provider" package. Directory tempDir = await getTemporaryDirectory(); String tempPath = tempDir.path; CookieJar cj=new PersistCookieJar(dir:tempPath);
APIs #
void saveFromResponse(Uri uri, List
Save the cookies for specified uri.
List
Load the cookies for specified uri.
delete(Uri uri,[bool withDomainSharedCookie = false] )
Delete cookies for specified uri
. This API will delete all cookies for the uri.host
, it will ignored the uri.path
.
If withDomainSharedCookie
is true
, will delete the domain-shared cookies.
Note: This API is only available in PersistCookieJar
class.
Working with HttpClient
#
Using CookieJar
or PersistCookieJar
manages HttpClient
's request/response cookies is very easy:
var cj=new CookieJar();
...
request= await httpClient.openUrl(options.method, uri);
request.cookies.addAll(cj.loadForRequest(uri));
response= await request.close();
cj.saveFromResponse(uri, response.cookies);
Working with dio #
dio is a powerful Http client for Dart, which supports Interceptors, Global configuration, FormData, File downloading, Timeout etc. And dio supports to manage cookies with cookie_jar, the simple example is:
var dio = new Dio();
dio.cookieJar=new PersistCookieJar(dir:"./cookies");
Response<String> response = await dio.get("https://www.baidu.com");
More details about dio see : https://github.com/flutterchina/dio .
Copyright & License #
This open source project authorized by https://flutterchina.club , and the license is MIT.
Features and bugs #
Please file feature requests and bugs at the issue tracker.