为什么带有空格的 cookie 值到达客户端时会带有引号?

2024-01-26

我是一名 .NET 开发人员,开始涉足 Java。

在 .NET 中,我可以将 cookie 的值设置为其中包含空格的字符串:new HttpCookie("myCookieName", "my value")- 当我在客户端(JavaScript)读取该值时,我得到了我期望的值(我的值)。

如果我在 Java servlet 中做同样的事情 -new Cookie("myCookieName", "my value"),我得到的值包括双引号(“我的值”)。

为什么有区别?我错过了什么吗?在 Java 世界中人们如何处理这个问题?您是否对值进行编码,然后在客户端进行解码?


当您使用以下值之一设置 cookie 值时,如中所述Cookie#setValue() https://jakarta.ee/specifications/platform/10/apidocs/jakarta/servlet/http/cookie#setValue(java.lang.String),

对于版本 0 cookie,值不应包含空格、方括号、圆括号、等号、逗号、双引号、斜杠、问号、at 符号、冒号和分号。空值在所有浏览器上的行为方式可能不同。

那么一般容器都会隐式地将cookie设置为版本1(RFC 2109 规范 https://www.ietf.org/rfc/rfc2109.txt) 而不是默认版本 0 (网景规范 https://curl.se/rfc/cookie_spec.html)。该行为不是由 Servlet API 指定的,容器可以自由地实现它(例如,它可能会抛出一些IllegalArgumentException)。据我所知,Tomcat、JBoss AS 和 Glassfish 在隐式更改 cookie 版本方面的行为完全相同。至少对于 Tomcat 和 JBoss AS 来说,这是修复的结果这个安全问题 https://access.redhat.com/security/cve/CVE-2007-5333.

版本 1 的 cookie 如下所示:


name="value with spaces";Max-Age=3600;Path=/;Version=1  

而版本 0 兼容的 cookie 看起来像这样:


name=value%20with%20spaces;Expires=Mon, 29-Aug-2011 14:30:00 GMT;Path=/  

(请注意,URL 编码值对于版本 0 有效)

重要提示是 Microsoft Internet Explorer 不支持版本 1 cookie。它将把引号解释为整个 cookie 值的一部分,并相应地处理和返回它。它不支持Max-Age属性,它会完全忽略它,这会导致 cookie 的生命周期默认为浏览器会话。您显然正在使用 IE 来测试您的 web 应用程序的 cookie 处理。

如果您希望支持不支持版本 1 cookie 的浏览器,那么您需要自己对 cookie 值进行 URL 编码和 URL 解码:

Cookie cookie = new Cookie(name, URLEncoder.encode(value, "UTF-8"));
// ...

and

String value = URLDecoder.decode(cookie.getValue(), "UTF-8"));
// ...
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

为什么带有空格的 cookie 值到达客户端时会带有引号? 的相关文章

随机推荐

  • 批量验证 yaml 文件

    我需要验证一大堆 YAML 文件 我尝试了 yaml 在线解析器 http yaml online parser appspot com http yaml online parser appspot com 效果很完美 但是将每个 YAM
  • 将 HttpContent 转换为 byte[]

    我目前正在开发 C Web API 对于特定调用 我需要使用 ajax 调用 API 发送 2 个图像 以便 API 可以将它们以 varbinary max 形式保存在数据库中 你如何提取一个Image or byte from a Ht
  • 如何打开没有菜单项的侧边栏?

    是否可以打开侧边栏而无需打开菜单并单击某个项目 我的意思是我们可以添加一个像按钮一样的菜单并在单击时打开侧边栏吗 我知道的最短的方法是将单个项目添加到菜单中 function onOpen e SpreadsheetApp getUi cr
  • 如何在 quill 编辑器中使用 v-model

    我用的是Vue 3 我以前用过这个 效果很好
  • mysql:信息架构上的访问被拒绝

    当我创建新用户或向现有用户授予权限时 出现此错误 ERROR 1045 28000 Access denied for user root localhost using password YES 对除 information schema
  • 迭代范围内的单元格时出现类型不匹配错误

    您好 我正在尝试在电子表格上运行以下 vb 代码 但在范围内出现数据类型不匹配的错误 我只是想锁定值为 0 的单元格 有些单元格的值为 NA 有什么想法吗 Sub Test Dim Cell As Range Set MyPlage Ran
  • Maven glassfish 嵌入式插件中的 JSP 热插拔

    我正在尝试设置嵌入式 glassfish maven 插件并且成功了 但是我无法使 jsp 文件热交换 这是我的配置
  • 10k 租户和多租户数据库设计 [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 我们正在尝试为新的 Web 应用程序决定数据库设计 我们预计将有近 10 000 个租户 并且希望将他们的数据保存在单独的数据库中 如
  • Qt iOS 运行失败

    当我尝试在 iOS 模拟器上运行我的应用程序时 应用程序输出 I see Starting remote process Run ended 当我尝试在 iPhone 上运行它时 Issues I see xcodebuild failed
  • 如何在休眠中为自身实体添加@onetoone映射

    如何为自身实体添加一对一映射 就像这个例子一样 我想为 Person 本身建立父子关系 Entity Table name PERSON public class Person Id Column name personId private
  • 在 make 中“触及”目标是什么意思?

    例如 从 mingw32 make exe help 选项 t touch Touch targets instead of remaking them 它只是意味着更新文件修改时间 这样下次就不会认为这些文件是旧的
  • CSS - 在电脑上分屏但在移动设备上堆叠

    我试图将我的页面分成 4 个相等的部分 我想将左上角水平分成 2 个部分 我主要关心的是它在移动设备上的表现 我不希望它像在电脑上那样被分割 我希望它被堆叠起来 块在另一个上面 如图所示 我想过引导网格 但我做不到 到目前为止我所拥有的内容
  • 如何使用量角器+角度获取迭代器索引/键?

    通过中继器查找元素时有没有办法访问迭代器索引 键 protractor By repeater id cat in pets 在本例中 我希望访问猫的 id id 不是表中显示为值的列之一 它用于导航ng click goto pets c
  • SSL_connect 返回=1 errno=0 状态=SSLv3 读取服务器证书 B:证书验证失败

    我在用Authlogic 连接 https github com viatropos authlogic connect用于第三方登录 运行适当的迁移后 Twitter Google yahoo 登录似乎工作正常 但 facebook 登录
  • 为什么 Python 中对集合的处理不统一?

    Python 中集合和列表的处理方式不同 并且似乎没有统一的方法来处理这两者 例如 将一个项目添加到set是使用完成的add方法 并且对于list它是使用完成的append方法 我知道这背后有不同的语义 但也有共同的语义 并且通常与某些集合
  • 用于电子邮件的 JUnit 报告单页 XSLT

    我有一个 Junit 进程 每天晚上运行大量数据完整性测试 我希望它以格式良好的 HTML 电子邮件形式发送结果 问题是 JUnit 中内置的 HTML 格式化程序使用框架和外部样式表 因此它不适合电子邮件 普通格式化程序将结果埋在一堆原本
  • 未捕获的语法错误:计算时出现意外的标识符

    我有一些返回一个的代码Uncaught SyntaxError当我运行它但我不明白为什么 我尝试将其通过 JSHint 但无济于事 这是明显错误的代码 function compute expr x string var whatisx x
  • Java8计算地图中对象列表的平均值

    初始数据 public class Stats int passesNumber int tacklesNumber public Stats int passesNumber int tacklesNumber this passesNu
  • MongoDB:如何在 C# 中加载带有嵌套数组的集合?

    我有一个名为 服务器 的集合 其中包含以下文档 name West ip 123 123 123 123 channels name English port 1234 status 0 name Spanish port 1235 sta
  • 为什么带有空格的 cookie 值到达客户端时会带有引号?

    我是一名 NET 开发人员 开始涉足 Java 在 NET 中 我可以将 cookie 的值设置为其中包含空格的字符串 new HttpCookie myCookieName my value 当我在客户端 JavaScript 读取该值时