我是靠谱客的博主 漂亮小伙,最近开发中收集的这篇文章主要介绍response.addCookie(cookie)设置的cookike名字只能为JSESSIONID 错误,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
文章目录
- 1、问题说明
- 2、解决问题
- 3、总结
1、问题说明
百度了很多答案,大致都是说注意设置domain和path
先附上我的 CookiUtil类,这里可以获取、创建、删除Cookie。
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
/**
* @param
* @return
*/
public class CookieUtil {
/***
* 获得cookie中的值,默认为主ip:www.gmall.com
* @param request
* @param cookieName
* @param isDecoder
* @return
*/
public static String getCookieValue(HttpServletRequest request, String cookieName, boolean isDecoder) {
Cookie[] cookies = request.getCookies();
if (cookies == null || cookieName == null){
return null;
}
String retValue = null;
try {
for (int i = 0; i < cookies.length; i++) {
if (cookies[i].getName().equals(cookieName)) {
if (isDecoder) {//如果涉及中文
retValue = URLDecoder.decode(cookies[i].getValue(), "UTF-8");
} else {
retValue = cookies[i].getValue();
}
break;
}
}
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return retValue;
}
/***
* 设置cookie的值
* @param request
* @param response
* @param cookieName
* @param cookieValue
* @param cookieMaxage
* @param isEncode
*/
public static void setCookie(HttpServletRequest request, HttpServletResponse response, String cookieName, String cookieValue, int cookieMaxage, boolean isEncode) {
try {
if (cookieValue == null) {
cookieValue = "";
} else if (isEncode) {
cookieValue = URLEncoder.encode(cookieValue, "utf-8");
}
Cookie cookie = new Cookie(cookieName, cookieValue);
if (cookieMaxage >= 0){
cookie.setMaxAge(cookieMaxage);
}
if (null != request)// 设置域名的cookie
{
cookie.setDomain(getDomainName(request));
}
// 在域名的根路径下保存
cookie.setPath("/");
response.addCookie(cookie);
request.getSession();
} catch (Exception e) {
e.printStackTrace();
}
}
/***
* 获得cookie的主域名,本系统为gmall.com,保存时使用
* @param request
* @return
*/
private static final String getDomainName(HttpServletRequest request) {
String domainName = null;
String serverName = request.getRequestURL().toString();// 获得浏览器地址栏的url
if (serverName == null || serverName.equals("")) {
domainName = "";
} else {
serverName = serverName.toLowerCase();
serverName = serverName.substring(7);
final int end = serverName.indexOf("/");
serverName = serverName.substring(0, end);
final String[] socket = serverName.split("\:");
if (socket.length == 2){
//若是通过套接字访问的 即ip+端口号的地址 先去掉端口号
domainName = socket[0];
}else {
//若不是直接通过套接字访问的
final String[] domains = serverName.split("\.");
int len = domains.length;
if (len > 3) {
// www.xxx.com.cn
domainName = domains[len - 3] + "." + domains[len - 2] + "." + domains[len - 1];
} else if (len <= 3 && len > 1) {
// xxx.com or xxx.cn
domainName = domains[len - 2] + "." + domains[len - 1];
} else {
domainName = serverName;
}
}
if (domainName != null && domainName.indexOf(":") > 0) {
String[] ary = domainName.split("\:");
domainName = ary[0];
}
}
System.out.println("domainName = " + domainName);
return domainName;
}
/***
* 将cookie中的内容按照key删除
* @param request
* @param response
* @param cookieName
*/
public static void deleteCookie(HttpServletRequest request, HttpServletResponse response, String cookieName) {
setCookie(request, response, cookieName, null, 0, false);
}
}
2、解决问题
本人的错误就是domain没有设置好
也就是自己的CookiUtil类没写好,导致直接通过套接字不能正确的分离出ip地址,若是使用域名就没有问题。
- 先判断是否为套接字直接访问,要不然我的算法在判断域名时,若是套接字会出现分割错误。
- 得到正确的域名domain之后Cookie设置成功
3、总结
遇到问题先debug看下自己的参数设置是否有问题,也看下自己浏览器的请求和相应控制台。
比如domain必须是一个有效可以访问的域名,否则就无法生成自己设置cookie,浏览器会自动生成一个JSESSIONID
最后
以上就是漂亮小伙为你收集整理的response.addCookie(cookie)设置的cookike名字只能为JSESSIONID 错误的全部内容,希望文章能够帮你解决response.addCookie(cookie)设置的cookike名字只能为JSESSIONID 错误所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复