Skip to content
New issue

Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? # to your account

JSON-RPC payloads don't need urldecode step #449

Closed
cl0ne opened this issue Feb 21, 2022 · 1 comment · Fixed by #450
Closed

JSON-RPC payloads don't need urldecode step #449

cl0ne opened this issue Feb 21, 2022 · 1 comment · Fixed by #450

Comments

@cl0ne
Copy link
Contributor

cl0ne commented Feb 21, 2022

For 14 years due to problems with some JS library (5749449) JSON-RPC request handler expects payload to be URL encoded.

JSON-RPC specification doesn't even mention the need for percent-encoding at all (same goes for older spec). None of the popular JSON-RPC clients (at least, this applies to Perl, C#, Java, Python implementations) apply URL encoding to the produced JSON request. Consequently, any method parameter that contains percent symbol will be either decoded to a wrong value, or will more often cause request handling failure.

The example from "AJAX through JSON-RPC" documentation page is broken due to this issue as well. Just include percent symbol in any of the submitted arguments, and you'll get either response code 500 (when the resulting character sequence is not valid, e.g. hello%world), or received request with different argument values (e.g., hello%20world becomes hello world).

This can hardly be expected as a correct behaviour for JSON-RPC server, even though correcting it is a backwards-incompatible change.

@vinoski
Copy link
Collaborator

vinoski commented Feb 27, 2022

Thanks for the explanation. I agree the current code is incorrect, and given the lack of complaints about it, I think it will be OK in this case to break backwards-compatibility in favor of correct behavior.

# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
None yet
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants