/* * Copyright (c) 2005, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ package java.net; import java.util.List; import java.util.Map; /** * A CookieStore object represents a storage for cookie. Can store and retrieve * cookies. * *
{@link CookieManager} will call CookieStore.add to save cookies * for every incoming HTTP response, and call CookieStore.get to * retrieve cookie for every outgoing HTTP request. A CookieStore * is responsible for removing HttpCookie instances which have expired. * * @author Edward Wang * @since 1.6 */ public interface CookieStore { /** * Adds one HTTP cookie to the store. This is called for every * incoming HTTP response. * *
A cookie to store may or may not be associated with an URI. If it * is not associated with an URI, the cookie's domain and path attribute * will indicate where it comes from. If it is associated with an URI and * its domain and path attribute are not speicifed, given URI will indicate * where this cookie comes from. * *
If a cookie corresponding to the given URI already exists,
* then it is replaced with the new one.
*
* @param uri the uri this cookie associated with.
* if null, this cookie will not be associated
* with an URI
* @param cookie the cookie to store
*
* @throws NullPointerException if cookie is null
*
* @see #get
*
*/
public void add(URI uri, HttpCookie cookie);
/**
* Retrieve cookies associated with given URI, or whose domain matches the
* given URI. Only cookies that have not expired are returned.
* This is called for every outgoing HTTP request.
*
* @return an immutable list of HttpCookie,
* return empty list if no cookies match the given URI
*
* @throws NullPointerException if uri is null
*
* @see #add
*
*/
public List