CookieUtils支持中文Cookie名称

This commit is contained in:
thinkgem
2019-06-12 09:37:58 +08:00
parent 605c38c74d
commit 59dd3bb743

View File

@@ -3,14 +3,11 @@
*/
package com.jeesite.common.web;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.jeesite.common.codec.EncodeUtils;
import com.jeesite.common.lang.StringUtils;
/**
@@ -60,14 +57,12 @@ public class CookieUtils {
*/
public static void setCookie(HttpServletResponse response, String name, String value, String path, int maxAge) {
if (StringUtils.isNotBlank(name)){
name = EncodeUtils.encodeUrl(name);
value = EncodeUtils.encodeUrl(value);
Cookie cookie = new Cookie(name, null);
cookie.setPath(path);
cookie.setMaxAge(maxAge);
try {
cookie.setValue(URLEncoder.encode(value, "utf-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
cookie.setValue(value);
response.addCookie(cookie);
}
}
@@ -113,15 +108,12 @@ public class CookieUtils {
public static String getCookie(HttpServletRequest request, HttpServletResponse response, String name, String path, boolean isRemove) {
String value = null;
if (StringUtils.isNotBlank(name)){
name = EncodeUtils.encodeUrl(name);
Cookie[] cookies = request.getCookies();
if (cookies != null) {
for (Cookie cookie : cookies) {
if (cookie.getName().equals(name)) {
try {
value = URLDecoder.decode(cookie.getValue(), "utf-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
value = EncodeUtils.decodeUrl(cookie.getValue());
if (isRemove && response != null) {
cookie.setPath(path);
cookie.setMaxAge(0);