Java tutorial
//$Id: CookieUtils.java,v 1.1 2007-3-21 ?09:10:05 chaostone Exp $ /* * Copyright c 2005-2009 * Licensed under GNU LESSER General Public License, Version 3. * http://www.gnu.org/licenses * */ /******************************************************************************** * @author chaostone * * MODIFICATION DESCRIPTION * * Name Date Description * ============ ============ ============ *chaostone 2007-3-21 Created * ********************************************************************************/ package org.beanfuse.utils.web; import java.io.UnsupportedEncodingException; import javax.servlet.http.Cookie; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.apache.commons.codec.net.URLCodec; import org.slf4j.Logger; import org.slf4j.LoggerFactory; public final class CookieUtils { private static final Logger LOG = LoggerFactory.getLogger(CookieUtils.class); private CookieUtils() { } public static String getCookieValue(Cookie cookie) { try { return new URLCodec().decode(cookie.getValue(), "utf-8"); } catch (Exception e) { return null; } } /** * ?cookievalue<br> * ?<br> * * @param request * @param cookieName * @return */ public static String getCookieValue(HttpServletRequest request, String cookieName) { try { Cookie cookie = getCookie(request, cookieName); if (null == cookie) { return null; } else { return new URLCodec("utf-8").decode(cookie.getValue()); } } catch (Exception e) { return null; } } /** * Convenience method to get a cookie by name * * @param request * the current request * @param name * the name of the cookie to find * * @return the cookie (if found), null if not found */ public static Cookie getCookie(HttpServletRequest request, String name) { Cookie[] cookies = request.getCookies(); Cookie returnCookie = null; if (cookies == null) { return returnCookie; } for (int i = 0; i < cookies.length; i++) { Cookie thisCookie = cookies[i]; if (thisCookie.getName().equals(name) && !thisCookie.getValue().equals("")) { returnCookie = thisCookie; break; } } return returnCookie; } /** * Convenience method to set a cookie <br> * value?<br> * * @param response * @param name * @param value * @param path */ public static void setCookie(HttpServletRequest request, HttpServletResponse response, String name, String value, String path, int age) { LOG.debug("add cookie[name:{},value={},path={}]", new String[] { name, value, path }); Cookie cookie = null; try { cookie = new Cookie(name, new URLCodec().encode(value, "utf-8")); } catch (UnsupportedEncodingException e) { throw new RuntimeException(e); } cookie.setSecure(false); cookie.setPath(path); cookie.setMaxAge(age); response.addCookie(cookie); } /** * * * @param request * @param response * @param name * @param value * @param age * @throws Exception */ public static void setCookie(HttpServletRequest request, HttpServletResponse response, String name, String value, int age) { String contextPath = request.getContextPath(); if (!contextPath.endsWith("/")) { contextPath += "/"; } setCookie(request, response, name, value, contextPath, age); } public static void deleteCookieByName(HttpServletRequest request, HttpServletResponse response, String name) { deleteCookie(response, getCookie(request, name), ""); } /** * Convenience method for deleting a cookie by name * * @param response * the current web response * @param cookie * the cookie to delete * @param path * the path on which the cookie was set (i.e. /appfuse) */ public static void deleteCookie(HttpServletResponse response, Cookie cookie, String path) { if (cookie != null) { // Delete the cookie by setting its maximum age to zero cookie.setMaxAge(0); cookie.setPath(path); response.addCookie(cookie); } } }