diff options
author | kennyj <kennyj@gmail.com> | 2013-09-19 02:40:03 +0900 |
---|---|---|
committer | kennyj <kennyj@gmail.com> | 2013-09-19 02:43:22 +0900 |
commit | 0cc65081200fe93acf0058829bb9dd7c41e59e9d (patch) | |
tree | e3d7efcb6d6037f80cd4ac3b5e6b5dcc9e39705a /actionpack | |
parent | 949c4291a4bffae582dc3987e8f4980ea13a2cff (diff) | |
download | rails-0cc65081200fe93acf0058829bb9dd7c41e59e9d.tar.gz rails-0cc65081200fe93acf0058829bb9dd7c41e59e9d.tar.bz2 rails-0cc65081200fe93acf0058829bb9dd7c41e59e9d.zip |
Fix an issue where router can't recognize downcased url encoding path.
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/CHANGELOG.md | 6 | ||||
-rw-r--r-- | actionpack/lib/action_dispatch/journey/router/utils.rb | 1 | ||||
-rw-r--r-- | actionpack/test/controller/routing_test.rb | 4 |
3 files changed, 11 insertions, 0 deletions
diff --git a/actionpack/CHANGELOG.md b/actionpack/CHANGELOG.md index 01e816e87c..63a208dbcf 100644 --- a/actionpack/CHANGELOG.md +++ b/actionpack/CHANGELOG.md @@ -1,3 +1,9 @@ +* Fix an issue where router can't recognize downcased url encoding path. + + Fixes #12269 + + *kennyj* + * Fix custom flash type definition. Misusage of the `_flash_types` class variable caused an error when reloading controllers with custom flash types. diff --git a/actionpack/lib/action_dispatch/journey/router/utils.rb b/actionpack/lib/action_dispatch/journey/router/utils.rb index 462f1a122d..80011597aa 100644 --- a/actionpack/lib/action_dispatch/journey/router/utils.rb +++ b/actionpack/lib/action_dispatch/journey/router/utils.rb @@ -16,6 +16,7 @@ module ActionDispatch path = "/#{path}" path.squeeze!('/') path.sub!(%r{/+\Z}, '') + path.gsub!(/(%[a-f0-9]{2}+)/) { $1.upcase } path = '/' if path == '' path end diff --git a/actionpack/test/controller/routing_test.rb b/actionpack/test/controller/routing_test.rb index f735564305..46df1a7bd5 100644 --- a/actionpack/test/controller/routing_test.rb +++ b/actionpack/test/controller/routing_test.rb @@ -1904,6 +1904,10 @@ class RackMountIntegrationTests < ActiveSupport::TestCase assert_equal({:controller => 'news', :action => 'index'}, @routes.recognize_path(URI.parser.escape('こんにちは/世界'), :method => :get)) end + def test_downcased_unicode_path + assert_equal({:controller => 'news', :action => 'index'}, @routes.recognize_path(URI.parser.escape('こんにちは/世界').downcase, :method => :get)) + end + private def sort_extras!(extras) if extras.length == 2 |