项目当中用到cookie保存中文,但是会报如下错误:
Control character in cookie value, consider BASE64 encoding your value
大概意思是保存到cookie当中的值存在控制字符,无法保存。但实际上数据是不存在这种问题的。再看后面的那句话,好像是将要保存的值进行了base64编码,可能是因为中文在编码时出现乱码导致一些控制字符的出现。
解决方案:将要保存的值进行URLEncoder.encode(value,"utf-8")编码。
在提取时,同样进行解码:
/**
* 添加一个cookie值
* @param name 名称
* @param value 值
* @param time cookie的有效期
* @param response 保存cookie的对象
*/
public static void setCookie(String name, String value, Integer time,HttpServletResponse response) {
try {
//关键点
value = URLEncoder.encode(value,"UTF-8");
} catch (UnsupportedEncodingException e) { }
Cookie cookie = new Cookie(name, value);
cookie.setPath("/");
cookie.setMaxAge(time);
response.addCookie(cookie);
}
/**
* 根据name值,从cookie当中取值
*
* @param name 要获取的name
* @param request cookie存在的对象
* @return 与name对应的cookie值
*/
public static String getCookie(String name, HttpServletRequest request) {
Cookie[] cs = request.getCookies();
String value = "";
if (cs != null) {
for (Cookie c : cs) {
if (name.equals(c.getName())) {
try {
//关键点
value = URLDecoder.decode(c.getValue(),"UTF-8");
} catch (UnsupportedEncodingException e) {
}
return value;
}
}
}
return value;
}
分享到:
相关推荐
当在Android的Webview中使用`localStorage`遇到问题时,有以下两种常见解决方案: 1. 使用Cookie:Cookie是一种在客户端和服务器之间传递信息的方式,虽然每个Cookie的大小限制在4KB左右,但可以通过设置多个Cookie...
总的来说,`js-cookie-jar` 提供了一套优雅的解决方案,使得前端开发者能够更加高效地管理Cookie,避免了处理字符串和手动解析的麻烦。在实际项目中,特别是在需要频繁操作Cookie的情况下,使用这个库可以大大提高...
### 自整理Java关于基础和框架的面试题 #### 基础知识点 ##### JDK常用的包 - **java.lang**: 包含所有基本类,如`String`、`Math`等。...- Spring是一个开源框架,提供了一整套的企业级服务解决方案...
- **Hibernate**:全ORM解决方案,自动管理对象的生命周期。 - **MyBatis (原Ibatis)**:半ORM框架,提供动态SQL支持。 - **JDBC**:直接与数据库交互,灵活性高但编码繁琐。 ##### Hibernate的运行原理 - **...
标题 "解决方案 ‘Access-Control-Allow-Origin’ header in the response must not be the wildcard ‘*’" 提到的是一个在Web开发中常见的跨域问题。`Access-Control-Allow-Origin` 是一个用于控制资源跨域访问的...
解决方案:在 FreeMarkerViewExtend.java 33行处 增加了BasePath ,通过BasePath 来控制请求目录,在 Freemarker 中可以自由使用,而 JSP 中是直接在 JSP 中获取BasePath 使用。 解决后遗症:因为我们的权限是通过...
CORS 规范化的跨域请求解决方案,安全可靠 什么是cors 它允许浏览器向跨源服务器,发出XMLHttpRequest请求,从而克服了AJAX只能同源使用的限制。 原理 简单请求 当浏览器发现发现的ajax请求是简单请求时,会在...