1

我一直在尝试对 HTTP 响应标头进行单元测试。我需要从标头接收 cookie。我得到了两个Set-Cookie标题,但我需要一个用于身份验证。返回的标头是:

HTTP/1.1 200 OK
Server: Cowboy
Connection: close
Set-Cookie: heroku-session-affinity=ADaDaANoA24IARpRKtf///8HYgABgzdiAAJZ5WECbAAAAAJtAAAABXdlYi4ybQAAAAV3ZWIuMWpcXMFamSToBPxyiOHM7o5AwvVZ3g__; Version=1; Expires=Thu, 12-Jan-2017 01:45:27 GMT; Max-Age=86400; Domain=xxxxxxxx.xxxx.xx; Path=/; HttpOnly
X-Powered-By: Express
Vary: Origin
Access-Control-Allow-Credentials: true
Content-Type: application/json; charset=utf-8
Content-Length: 30914
Etag: W/"78c2-veX2kgrO3zh118nYsOP80A"
Set-Cookie: connect.sid=s%3Adl1_47SY9vlKlHOguBvjZpmaa2WTUhHG.O2j9YOShB4AX0rAC5RRj%2BeCXAB11s5q1DB4x4fiHE4A; Path=/; Expires=Fri, 13 Jan 2017 01:45:27 GMT; HttpOnly
Date: Wed, 11 Jan 2017 01:45:27 GMT
Via: 1.1 vegur

我添加了一个包含这些值的测试文件:

{
    "Server": "Cowboy",
    "Connection": "close",
    "Set-Cookie": "heroku-session-affinity=ADaDaANoA24IAXtpQOD///8HYgAAKehiAA6V12ECbAAAAAJtAAAABXdlYi4ybQAAAAV3ZWIuMWrNqkap0u4H0uG3Btrtlamaq2nQ5w__; Version=1; Expires=Wed, 11-Jan-2017 01:12:09 GMT; Max-Age=86400; Domain=xxxxxxxx.xxxx.xx; Path=/; HttpOnly",
    "X-Powered-By": "Express",
    "Vary": "Origin",
    "Access-Control-Allow-Credentials": "true",
    "Content-Type": "application/json; charset=utf-8",
    "Content-Length": "30914",
    "Etag": "W/\"78c2-veX2kgrO3zh118nYsOP80A\"",
    "Set-Cookie": "connect.sid=s%3ACX3tfhPk9nlRtU8e8gtouQIx1kpP07h9.iExm%2F96Dgzuh289nmjwbYO49E0Bq0WwUHmN539IkudI; Path=/; Expires=Thu, 12 Jan 2017 01:12:09 GMT; HttpOnly",
    "Date": "Tue, 10 Jan 2017 01:12:09 GMT",
    "Via": "1.1 vegur"
}

我需要第二个Set-Cookie值,但是当我尝试访问它的值时,我得到了第一个值Set-Cookie。我假设是因为我将标题放在字典中。但是当我在单元测试中存根响应时,标题所需的格式是字典。我只得到一个Set-Cookie标题,因为我不能在字典中拥有两个相同的键。

我做错了什么吗?

4

1 回答 1

1

RFC 7230,第 3.2.2 节介绍了如何处理 HTTP 标头;它取代了 RFC 2616。特别是,它说:

发送者不得在消息中生成具有相同字段名称的多个头字段,除非该头字段的整个字段值被定义为逗号分隔列表 [即,#(values)] 或头字段是一个很好的-已知异常(如下所述)。

而且,不幸的是,对于您的用例,它Set-Cookie 那些著名的“众所周知的例外”之一,因为它的语法(由RFC 6265涵盖)不容易适用于以逗号分隔的 cookie 值列表。

这意味着使用字典/哈希表结构来表示 HTTP 标头通常有效,但在Set-Cookie. 还有其他获取标头的方法;例如,请参阅此 StackOverflow 帖子。或者,如果您可以对除 之外的标头进行单元测试Set-Cookie可能是另一种方法。

希望这可以帮助!

于 2017-01-11T03:25:16.267 回答