diff options
author | mrkn <mrkn@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-01-20 11:48:52 +0000 |
---|---|---|
committer | mrkn <mrkn@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2012-01-20 11:48:52 +0000 |
commit | ce8d368b1ea4d6b97b7493074a0c041f59d5a5c1 (patch) | |
tree | 43c87ba9600df0542a24defd54484e9708a9bc54 | |
parent | 587135e9941306efee72346b0d00c82d8e8574e0 (diff) | |
download | ruby-ce8d368b1ea4d6b97b7493074a0c041f59d5a5c1.tar.gz |
* lib/cgi/util.rb (CGI.escape): support a string with invalid byte
sequence.
* test/cgi/test_cgi_util.rb
(test_cgi_escape_with_invalid_byte_sequence): test for the above
change.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@34346 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 9 | ||||
-rw-r--r-- | lib/cgi/util.rb | 5 | ||||
-rw-r--r-- | test/cgi/test_cgi_util.rb | 6 |
3 files changed, 18 insertions, 2 deletions
@@ -1,3 +1,12 @@ +Fri Jan 20 20:47:37 2012 Kenta Murata <mrkn@cookpad.com> + + * lib/cgi/util.rb (CGI.escape): support a string with invalid byte + sequence. + + * test/cgi/test_cgi_util.rb + (test_cgi_escape_with_invalid_byte_sequence): test for the above + change. + Fri Jan 20 17:37:37 2012 NARUSE, Yui <naruse@ruby-lang.org> * vm.c (vm_exec): remove workaround for LLVM because r34278 fixes it. diff --git a/lib/cgi/util.rb b/lib/cgi/util.rb index 2bb3b0da78..b877c1bae7 100644 --- a/lib/cgi/util.rb +++ b/lib/cgi/util.rb @@ -4,9 +4,10 @@ class CGI # url_encoded_string = CGI::escape("'Stop!' said Fred") # # => "%27Stop%21%27+said+Fred" def CGI::escape(string) - string.gsub(/([^ a-zA-Z0-9_.-]+)/) do + encoding = string.encoding + string.dup.force_encoding('ASCII-8BIT').gsub(/([^ a-zA-Z0-9_.-]+)/) do '%' + $1.unpack('H2' * $1.bytesize).join('%').upcase - end.tr(' ', '+') + end.tr(' ', '+').force_encoding(encoding) end # URL-decode a string with encoding(optional). diff --git a/test/cgi/test_cgi_util.rb b/test/cgi/test_cgi_util.rb index 71e8beac3d..f34703e9d8 100644 --- a/test/cgi/test_cgi_util.rb +++ b/test/cgi/test_cgi_util.rb @@ -24,6 +24,12 @@ class CGIUtilTest < Test::Unit::TestCase assert_equal('%26%3C%3E%22+%E3%82%86%E3%82%93%E3%82%86%E3%82%93'.ascii_only?, CGI::escape(@str1).ascii_only?) if defined?(::Encoding) end + def test_cgi_escape_with_invalid_byte_sequence + assert_nothing_raised(ArgumentError) do + assert_equal('%C0%3C%3C', CGI::escape("\xC0<<".force_encoding("UTF-8"))) + end + end + def test_cgi_unescape assert_equal(@str1, CGI::unescape('%26%3C%3E%22+%E3%82%86%E3%82%93%E3%82%86%E3%82%93')) assert_equal(@str1.encoding, CGI::unescape('%26%3C%3E%22+%E3%82%86%E3%82%93%E3%82%86%E3%82%93').encoding) if defined?(::Encoding) |