mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-19 18:13:55 +00:00
Error on multibyte characters in HTTP request
* lisp/url/url-http.el (url-http-create-request): Check the constructed request in the end to verify that it does not contain multibyte characters (bug#23750).
This commit is contained in:
parent
ea512a7c2c
commit
a98aa02a5d
@ -275,19 +275,7 @@ request.")
|
||||
;; allows us to elide null lines directly, at the cost of making
|
||||
;; the layout less clear.
|
||||
(setq request
|
||||
;; We used to concat directly, but if one of the strings happens
|
||||
;; to being multibyte (even if it only contains pure ASCII) then
|
||||
;; every string gets converted with `string-MAKE-multibyte' which
|
||||
;; turns the 127-255 codes into things like latin-1 accented chars
|
||||
;; (it would work right if it used `string-TO-multibyte' instead).
|
||||
;; So to avoid the problem we force every string to be unibyte.
|
||||
(mapconcat
|
||||
;; FIXME: Instead of `string-AS-unibyte' we'd want
|
||||
;; `string-to-unibyte', so as to properly signal an error if one
|
||||
;; of the strings contains a multibyte char.
|
||||
'string-as-unibyte
|
||||
(delq nil
|
||||
(list
|
||||
(concat
|
||||
;; The request
|
||||
(or url-http-method "GET") " "
|
||||
(if using-proxy (url-recreate-url url-http-target-url) real-fname)
|
||||
@ -365,7 +353,10 @@ request.")
|
||||
"\r\n"
|
||||
;; Any data
|
||||
url-http-data))
|
||||
""))
|
||||
;; Bug#23750
|
||||
(unless (= (string-bytes request)
|
||||
(length request))
|
||||
(error "Multibyte text in HTTP request: %s" request))
|
||||
(url-http-debug "Request is: \n%s" request)
|
||||
request))
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user