먼저 쿠키가 무엇인지 알아보겠습니다.
쿠키는 실제로 귀하의 하드 드라이브에 저장되는 데이터이지만 이러한 데이터는 매우 특별하며 웹 애플리케이션을 통해서만 저장하기 위해 브라우저에 제출할 수 있습니다. 브라우저 쿠키를 읽는 기능도 있습니다
웹 애플리케이션은 일반적으로 일부 사용자 정보 등 소량의 임시 데이터만 쿠키에 저장합니다. 데이터 양이 많은 경우 쿠키에 저장하는 것은 적합하지 않습니다.
일반 브라우저는 적합하지 않습니다. 각 웹 애플리케이션에는 데이터를 저장하기 위해 40개의 쿠키가 제공되며, 각 쿠키의 크기는 4K를 초과하지 않습니다. (일부 브라우저 쿠키는 많은 양의 데이터를 저장할 수 있다고 들었지만 일반적으로 우리는 그렇게 많은 양의 데이터를 저장하지 마십시오. 데이터 추출의 효율성이 높지 않고 성능에 영향을 미치기 때문입니다.)
쓸데없는 말을 너무 많이 한 끝에 마침내 요점이 나옵니다.
java는 쿠키 데이터에 접근합니다. httpServletRequest 인터페이스를 통한 브라우저 요청(여기서는 먼저 쿠키의 내용을 이해하겠습니다. 코드는 나중에 제공됩니다)
각 쿠키에는 키, 값이라는 두 가지 속성이 있습니다(특정 형식 문자열이 없으므로 DIY로 데이터를 저장할 수 있지만 URL 인코딩 문제에 주의하세요. 코딩 문제는 나중에 코드와 함께 논의됩니다.)
새 쿠키를 저장해야 하는 경우 새 쿠키 인스턴스를 만들어 제출할 수 있습니다. httpserletRsponse를 통해 브라우저에 저장한 다음 로컬에 저장합니다.
아래와 같이 쿠키의 일반 클래스
/* * 该类可以从浏览器请求中提取出cookies并进行对cookis的相关操作 * */ public class CookiesUtil extends BaseController { /** * 根据名字获取cookie * * @param request * @param name * cookie名字 * @return */ public static Cookie getCookieByName(HttpServletRequest request, String name) { Map<String, Cookie> cookieMap = ReadCookieMap(request); if (cookieMap.containsKey(name)) { Cookie cookie = (Cookie) cookieMap.get(name); return cookie; } else { return null; } } /** * 将cookie封装到Map里面 * * @param request * @return */ private static Map<String, Cookie> ReadCookieMap(HttpServletRequest request) { Map<String, Cookie> cookieMap = new HashMap<String, Cookie>(); Cookie[] cookies = request.getCookies(); if (null != cookies) { for (Cookie cookie : cookies) { cookieMap.put(cookie.getName(), cookie); } } return cookieMap; } /** * 保存Cookies * * @param response * servlet请求 * @param value * 保存值 * @author jxf */ public static HttpServletResponse setCookie(HttpServletResponse response, String name, String value,int time) { // new一个Cookie对象,键值对为参数 Cookie cookie = new Cookie(name, value); // tomcat下多应用共享 cookie.setPath("/"); // 如果cookie的值中含有中文时,需要对cookie进行编码,不然会产生乱码 try { URLEncoder.encode(value, "utf-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } cookie.setMaxAge(time); // 将Cookie添加到Response中,使之生效 response.addCookie(cookie); // addCookie后,如果已经存在相同名字的cookie,则最新的覆盖旧的cookie return response; }
위의 일반 클래스를 사용하여 여기서 새 쿠키를 읽고 생성할 수 있습니다. 한 가지 더 언급하자면, 새 쿠키의 이름이 이미 브라우저에 존재하는 경우에는 다시 추가되지 않으며 이전 쿠키를 덮어쓰게 됩니다.
브라우저는 요청된 쿠키와 반환된 쿠키를 어떻게 보나요? Google Chrome을 예로 들어 보겠습니다.
그런 다음 쿠키를 삭제해야 할 수도 있습니다.
/** * <p>删除无效cookie</p> * <p>无效?1.过时 2.未发布</p> * @param request * @param response * @param list */ private void delectCookieByName(HttpServletRequest request, HttpServletResponse response,String deleteKey) throws NullPointerException {12 Map<String, Cookie> cookieMap = ReadCookieMap(request);17 for (String key : cookieMap.keySet()) { if(key==deleteKey && key.equals(deleteKey)) { Cookie cookie = cookieMap.get(key);21 cookie.setMaxAge(0);//设置cookie有效时间为0 cookie.setPath("/");//不设置存储路径 response.addCookie(cookie); } } }
쿠키도 동시에 삭제해야 합니다. time 시간과 경로 매개변수가 있으며, 그렇지 않으면 일부 브라우저에서는 이를 삭제할 수 없습니다.
위는 Java 읽기 및 쓰기 브라우저 쿠키의 데이터 수집입니다. 앞으로도 관련 정보를 계속 추가하겠습니다. 이 사이트의!
Java가 브라우저 쿠키를 읽고 쓰는 방법에 대한 자세한 예를 보려면 PHP 중국어 웹사이트의 관련 기사를 참고하세요!