|  | /* | 
|  | * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved. | 
|  | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. | 
|  | * | 
|  | * This code is free software; you can redistribute it and/or modify it | 
|  | * under the terms of the GNU General Public License version 2 only, as | 
|  | * published by the Free Software Foundation.  Oracle designates this | 
|  | * particular file as subject to the "Classpath" exception as provided | 
|  | * by Oracle in the LICENSE file that accompanied this code. | 
|  | * | 
|  | * This code is distributed in the hope that it will be useful, but WITHOUT | 
|  | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | 
|  | * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License | 
|  | * version 2 for more details (a copy is included in the LICENSE file that | 
|  | * accompanied this code). | 
|  | * | 
|  | * You should have received a copy of the GNU General Public License version | 
|  | * 2 along with this work; if not, write to the Free Software Foundation, | 
|  | * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | 
|  | * | 
|  | * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA | 
|  | * or visit www.oracle.com if you need additional information or have any | 
|  | * questions. | 
|  | */ | 
|  |  | 
|  | package java.net; | 
|  |  | 
|  | import java.io.IOException; | 
|  | import java.util.Map; | 
|  | import java.util.List; | 
|  | import sun.security.util.SecurityConstants; | 
|  |  | 
|  | /** | 
|  | * Represents implementations of URLConnection caches. An instance of | 
|  | * such a class can be registered with the system by doing | 
|  | * ResponseCache.setDefault(ResponseCache), and the system will call | 
|  | * this object in order to: | 
|  | * | 
|  | *    <ul><li>store resource data which has been retrieved from an | 
|  | *            external source into the cache</li> | 
|  | *         <li>try to fetch a requested resource that may have been | 
|  | *            stored in the cache</li> | 
|  | *    </ul> | 
|  | * | 
|  | * The ResponseCache implementation decides which resources | 
|  | * should be cached, and for how long they should be cached. If a | 
|  | * request resource cannot be retrieved from the cache, then the | 
|  | * protocol handlers will fetch the resource from its original | 
|  | * location. | 
|  | * | 
|  | * The settings for URLConnection#useCaches controls whether the | 
|  | * protocol is allowed to use a cached response. | 
|  | * | 
|  | * For more information on HTTP caching, see <a | 
|  | * href="http://www.ietf.org/rfc/rfc2616.txt"><i>RFC 2616: Hypertext | 
|  | * Transfer Protocol -- HTTP/1.1</i></a> | 
|  | * | 
|  | * @author Yingxian Wang | 
|  | * @since 1.5 | 
|  | */ | 
|  | public abstract class ResponseCache { | 
|  |  | 
|  | /** | 
|  | * The system wide cache that provides access to a url | 
|  | * caching mechanism. | 
|  | * | 
|  | * @see #setDefault(ResponseCache) | 
|  | * @see #getDefault() | 
|  | */ | 
|  | private static ResponseCache theResponseCache; | 
|  |  | 
|  | /** | 
|  | * Gets the system-wide response cache. | 
|  | * | 
|  | * @throws  SecurityException | 
|  | *          If a security manager has been installed and it denies | 
|  | * {@link NetPermission}{@code ("getResponseCache")} | 
|  | * | 
|  | * @see #setDefault(ResponseCache) | 
|  | * @return the system-wide {@code ResponseCache} | 
|  | * @since 1.5 | 
|  | */ | 
|  | public synchronized  static ResponseCache getDefault() { | 
|  | SecurityManager sm = System.getSecurityManager(); | 
|  | if (sm != null) { | 
|  | sm.checkPermission(SecurityConstants.GET_RESPONSECACHE_PERMISSION); | 
|  | } | 
|  | return theResponseCache; | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Sets (or unsets) the system-wide cache. | 
|  | * | 
|  | * Note: non-standard procotol handlers may ignore this setting. | 
|  | * | 
|  | * @param responseCache The response cache, or | 
|  | *          {@code null} to unset the cache. | 
|  | * | 
|  | * @throws  SecurityException | 
|  | *          If a security manager has been installed and it denies | 
|  | * {@link NetPermission}{@code ("setResponseCache")} | 
|  | * | 
|  | * @see #getDefault() | 
|  | * @since 1.5 | 
|  | */ | 
|  | public synchronized static void setDefault(ResponseCache responseCache) { | 
|  | SecurityManager sm = System.getSecurityManager(); | 
|  | if (sm != null) { | 
|  | sm.checkPermission(SecurityConstants.SET_RESPONSECACHE_PERMISSION); | 
|  | } | 
|  | theResponseCache = responseCache; | 
|  | } | 
|  |  | 
|  | /** | 
|  | * Retrieve the cached response based on the requesting uri, | 
|  | * request method and request headers. Typically this method is | 
|  | * called by the protocol handler before it sends out the request | 
|  | * to get the network resource. If a cached response is returned, | 
|  | * that resource is used instead. | 
|  | * | 
|  | * @param uri a {@code URI} used to reference the requested | 
|  | *            network resource | 
|  | * @param rqstMethod a {@code String} representing the request | 
|  | *            method | 
|  | * @param rqstHeaders - a Map from request header | 
|  | *            field names to lists of field values representing | 
|  | *            the current request headers | 
|  | * @return a {@code CacheResponse} instance if available | 
|  | *          from cache, or null otherwise | 
|  | * @throws  IOException if an I/O error occurs | 
|  | * @throws  IllegalArgumentException if any one of the arguments is null | 
|  | * | 
|  | * @see     java.net.URLConnection#setUseCaches(boolean) | 
|  | * @see     java.net.URLConnection#getUseCaches() | 
|  | * @see     java.net.URLConnection#setDefaultUseCaches(boolean) | 
|  | * @see     java.net.URLConnection#getDefaultUseCaches() | 
|  | */ | 
|  | public abstract CacheResponse | 
|  | get(URI uri, String rqstMethod, Map<String, List<String>> rqstHeaders) | 
|  | throws IOException; | 
|  |  | 
|  | /** | 
|  | * The protocol handler calls this method after a resource has | 
|  | * been retrieved, and the ResponseCache must decide whether or | 
|  | * not to store the resource in its cache. If the resource is to | 
|  | * be cached, then put() must return a CacheRequest object which | 
|  | * contains an OutputStream that the protocol handler will | 
|  | * use to write the resource into the cache. If the resource is | 
|  | * not to be cached, then put must return null. | 
|  | * | 
|  | * @param uri a {@code URI} used to reference the requested | 
|  | *            network resource | 
|  | * @param conn - a URLConnection instance that is used to fetch | 
|  | *            the response to be cached | 
|  | * @return a {@code CacheRequest} for recording the | 
|  | *            response to be cached. Null return indicates that | 
|  | *            the caller does not intend to cache the response. | 
|  | * @throws IOException if an I/O error occurs | 
|  | * @throws IllegalArgumentException if any one of the arguments is | 
|  | *            null | 
|  | */ | 
|  | public abstract CacheRequest put(URI uri, URLConnection conn)  throws IOException; | 
|  | } |