我正试图在这样的grails服务中从请求中提取cookie:
def cookies = RequestContextHolder.currentRequestAttributes().getCurrentRequest().getCookies();
这样我就可以把它放回到我传递给Web服务的请求中。不幸的是我上面的cookie是javax.servlet.http.Cookie,当我想将cookie添加到RESTClient时,如下所示:
for (int i=0; i<cookies.length; i++) {
client.client.cookieStore.addCookie(cookies[i])
}
我发现addCookie期待一个org.apache.http.cookie.Cookie,我希望我不必进行完整的转换。谁能给我一些关于处理这个问题的最佳方法的建议?
提前致谢。
答案 0 :(得分:0)
谷歌查询“apache cookie convert servlet cookie”的第一个结果:
http://blog.sangupta.com/2010/10/convert-between-java-servlet-and-apache.html
答案 1 :(得分:0)
另一个答案已链接到现已失效的URL。该URL上托管的解决方案是Sandeep Gupta的Apache许可脚本。
解决方案基本上涉及使用公共获取程序复制每个属性。
/**
* Copyright (C) 2010, Sandeep Gupta
* http://www.sangupta.com
*
* The file is licensed under the the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package com.sangupta.util;
import java.util.Date;
import javax.servlet.http.Cookie;
/**
* Utility class to help convert Cookie objects between Java Servlet Cookie's
* and Apache HttpClient Cookie's.
*
* @author sangupta
* @version 1.0
* @since 30 Oct 2010
*/
public class ApacheCookieUtils {
/**
* Method to convert an Apache HttpClient cookie to a Java Servlet cookie.
*
* @param apacheCookie the source apache cookie
* @return a java servlet cookie
*/
public static Cookie servletCookieFromApacheCookie(org.apache.commons.httpclient.Cookie apacheCookie) {
if(apacheCookie == null) {
return null;
}
String name = apacheCookie.getName();
String value = apacheCookie.getValue();
Cookie cookie = new Cookie(name, value);
// set the domain
value = apacheCookie.getDomain();
if(value != null) {
cookie.setDomain(value);
}
// path
value = apacheCookie.getPath();
if(value != null) {
cookie.setPath(value);
}
// secure
cookie.setSecure(apacheCookie.getSecure());
// comment
value = apacheCookie.getComment();
if(value != null) {
cookie.setComment(value);
}
// version
cookie.setVersion(apacheCookie.getVersion());
// From the Apache source code, maxAge is converted to expiry date using the following formula
// if (maxAge >= 0) {
// setExpiryDate(new Date(System.currentTimeMillis() + maxAge * 1000L));
// }
// Reverse this to get the actual max age
Date expiryDate = apacheCookie.getExpiryDate();
if(expiryDate != null) {
long maxAge = (expiryDate.getTime() - System.currentTimeMillis()) / 1000;
// we have to lower down, no other option
cookie.setMaxAge((int) maxAge);
}
// return the servlet cookie
return cookie;
}
/**
* Method to convert a Java Servlet cookie to an Apache HttpClient cookie.
*
* @param cookie the Java servlet cookie to convert
* @return the Apache HttpClient cookie
*/
public static org.apache.commons.httpclient.Cookie apacheCookieFromServletCookie(Cookie cookie) {
if(cookie == null) {
return null;
}
org.apache.commons.httpclient.Cookie apacheCookie = null;
// get all the relevant parameters
String domain = cookie.getDomain();
String name = cookie.getName();
String value = cookie.getValue();
String path = cookie.getPath();
int maxAge = cookie.getMaxAge();
boolean secure = cookie.getSecure();
// create the apache cookie
apacheCookie = new org.apache.commons.httpclient.Cookie(domain, name, value, path, maxAge, secure);
// set additional parameters
apacheCookie.setComment(cookie.getComment());
apacheCookie.setVersion(cookie.getVersion());
// return the apache cookie
return apacheCookie;
}
}