-
-
Notifications
You must be signed in to change notification settings - Fork 153
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
URL Decoding of Raw Cookie Values #112
base: master
Are you sure you want to change the base?
URL Decoding of Raw Cookie Values #112
Conversation
Thanks! There are two issues with this, if you can help: (1) This is not backwards-compatible, as it will now throw for cookies like (2) Can you quote the part in the RFC that specifies that the decoding is URL decoding (i.e. percent decoding)? I tried looking in the link you provided, but didn't see it anywhere. Can you inline quote the exact thing the RFC says regarding that? |
@dougwilson Good point, I went back and looked at the RFC and expressjs documentation. The RFC doesn't specify the encoding to use, but rather recommends an encoding be used. Express by default will encode cookies using Would it perhaps be worth passing a |
How would that be different from just like writing |
The issue arises when you're using signed cookies. Signing of the cookie happens on the cookie value directly, but then the set-cookie might encode them both. Essentially, when trying to verify the signature, you need to potentially decode the raw cookie value before trying the various signing keys to find a signature match. What you end up having is:
and effectively, the following ends up being true:
|
Sorry @dougwilson , needed to translate my train of thought into english. |
So why not just set the cookie with this module if you're trying to get the cookie back again with this module? Then it will always do what you want. Otherwise you can just have res.cookie in express not encode the value in it's options. You're going to end up with this option between one of these two if you don't just use this module to set the cookie value too, and you can already set the encoding in express (for example, to just not encode), which seems like the simpler solution for your specific problem, right? |
Agreed that I could theoretically have express not encode the cookie, in this particular case, the service using cookie-session is behind a proxy which is managing the user's cookies. I figured that giving the ability to specify an encoding/decoding here would provide greater flexibility. |
The reason there is no option to encode / decode in this module was a design choice, not an accidental omission. The express API has issue and should not be copied here because it provides no way for the user to handle decoding errors, for example. The API choice of this module does, because you always get back the raw value and can then encode / decode as you like, including however you want to handle errors that happen during that process. |
With the exception of signatures. The opinion of this module is that the cookie's signature is based on the raw value. If the cookie value and its corresponding signature were encoded as part of the set-cookie, their contents will not match |
What does that have to do with handling decoding errors? I'm not sure I understand how your response fits in to what was quoted? |
That's right. So if you want to not use this module to generate the signature, you still have to do it in a compatible way... just like the name of the signature cookie has to end with ".sig" and not like ".foobar" |
URL decoding of raw cookie header key-value pairs as recommended by h…ttps://tools.ietf.org/html/rfc6265#section-4.1.1
Using cookie-session, signed cookies are not recognized when the serialized session cookie contains special characters such as
=
, since they end up being url encoded. This PR will URL Decode the raw values parsed from the cookie header.