-
Notifications
You must be signed in to change notification settings - Fork 9
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
Stance on using Query String instead of Header #97
Comments
Sensitive information like Authorization should not be passed in query string. Allowing insecure implementations is problematic: JWT needed a whole new draft to address security issues. Fetch specs support headers so afaik there should not be problems with mobile/client apps. If you have a more specific use-case (eg. language, mobile framework, browser, ...) please share :) My 2¢, |
@msporny can we close this issue? |
Sorry I intended to provide more information, but time got away from me. The scenario we have is using the NativeScript mobile application framework. NativeScript isn't super popular, but it basically just compiles down to native iOS and Android code. We're eventually moving to pure native. Anyway, we have a login web page that is launched from the app. It will load using the device's native browser (Chrome or Safari, depending on the device). We require the request to the login page to contain a signature. I believe when we call out to the browser from the app, we can pass headers to Chrome on Android. So that should work. However, I do not believe this is possible with iOS and Safari. It's possible I'm missing the solution. I'm not 100% clear on the Fetch spec link... it looks like that is more for client-side browser code? I'm definitely not a security expert, but understand at a high-level why sensitive information should not be in a query string. In my case, the signature would only be valid for a short amount of time. I've also read some of how AWS Signature Version 4 allows query string parameters, so based some of my opinion on that. Thanks for your responses! |
I'm curious about the stance of using the query string to provide the
Signature
orAuthorization
value, as opposed to the header? I know there are definitely some things to consider with that approach, such as URL limits, possibly changing what values are required for the signing string, etc. In fact, in this scenario one probably will not include any headers in the signature string.One use case I am thinking of is a mobile app that opens a URL in the device's browser. The mobile app may not be able to send headers, so would have no ability to sign the request.
Thanks,
Jason
The text was updated successfully, but these errors were encountered: