我的 Discourse 默认语言设置为日语。
部分默认组名已转换为日语,组的 URL(Slug)也是日语。
例如,Staff 组的 URL 是 /g/スタッフ。
Staff 活动页面的 URL 是 /g/スタッフ/activity/posts。
所有非英文名称的组都无法访问组消息页面 /g/スタッフ/messages。
尝试访问这些页面时,会出现服务器错误 500 消息。
我尝试在自定义文本页面查找这些文本,但认为无法对其进行自定义。
这似乎是一个漏洞,因为当我将语言改回英语并刷新页面后,这些非英语组名仍然保留为日语。
我有两个问题:
-
是否有可能修复非英语组的组消息错误?
-
我认为 Discourse 不允许使用非英语组名。那么我该如何将这些名称改回英语?
附注:我已更新到最新版本并重建了应用,但问题依然存在。
techAPJ
(Arpit Jalan)
3
在最新版本的 Discourse 上我无法复现此问题。
如果您将语言环境更新为英语,群组名称将在 12 小时内通过 EnsureDbConsistency 计划任务自动更新为“staff”。
感谢您的快速回复。
这是错误日志中显示的错误。
ActionController::UrlGenerationError (No route matches {:action=>"private_messages_group", :controller=>"list", :format=>"json", :group_name=>"トラストレベル 0", :page=>1, :topic_ids=>nil, :username=>"admin"}
ActionController::UrlGenerationError (No route matches {:action=>"private_messages_group", :controller=>"list", :format=>"json", :group_name=>"スタッフ", :page=>1, :topic_ids=>nil, :username=>"admin"}, po
ActionController::UrlGenerationError (No route matches {:action=>"private_messages_group", :controller=>"list", :format=>"json", :group_name=>"管理者", :page=>1, :topic_ids=>nil, :username=>"admin"}, pos
ActionController::UrlGenerationError (No route matches {:action=>"private_messages_group_archive", :controller=>"list", :format=>"json", :group_name=>"管理者", :page=>1, :topic_ids=>nil, :username=>"admi
详情:
信息
- ActionController::UrlGenerationError (No route matches {:action=>“private_messages_group”, :controller=>“list”, :format=>“json”, :group_name=>“管理者”, :page=>1, :topic_ids=>nil, :username=>“admin”}, possible unmatched constraints: [:group_name])
- app/controllers/list_controller.rb:416:in `public_send’
- app/controllers/list_controller.rb:416:in `construct_url_with’
- app/controllers/list_controller.rb:175:in `message_route’
- app/controllers/list_controller.rb:160:in `block in generate_message_route’
- app/controllers/application_controller.rb:358:in `block in with_resolved_locale’
- app/controllers/application_controller.rb:358:in `with_resolved_locale’
- lib/middleware/omniauth_bypass_middleware.rb:68:in `call’
- lib/content_security_policy/middleware.rb:12:in `call’
- lib/middleware/anonymous_cache.rb:355:in `call’
- config/initializers/100-quiet_logger.rb:23:in `call’
- config/initializers/100-silence_logger.rb:31:in `call’
- lib/middleware/enforce_hostname.rb:23:in `call’
- lib/middleware/request_tracker.rb:177:in `call’
回溯
- actionpack (6.0.3.5) lib/action_dispatch/journey/formatter.rb:57:in `generate’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:738:in `generate’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:769:in `generate’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:816:in `url_for’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:269:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:326:in `block in define_url_helper’
- app/controllers/list_controller.rb:416:in `public_send’
- app/controllers/list_controller.rb:416:in `construct_url_with’
- app/controllers/list_controller.rb:175:in `message_route’
- app/controllers/list_controller.rb:160:in `block in generate_message_route’
- actionpack (6.0.3.5) lib/action_controller/metal/basic_implicit_render.rb:6:in `send_action’
- actionpack (6.0.3.5) lib/abstract_controller/base.rb:195:in `process_action’
- actionpack (6.0.3.5) lib/action_controller/metal/rendering.rb:30:in `process_action’
- actionpack (6.0.3.5) lib/abstract_controller/callbacks.rb:42:in `block in process_action’
- activesupport (6.0.3.5) lib/active_support/callbacks.rb:112:in `block in run_callbacks’
- app/controllers/application_controller.rb:358:in `block in with_resolved_locale’
- i18n (1.8.9) lib/i18n.rb:314:in `with_locale’
- app/controllers/application_controller.rb:358:in `with_resolved_locale’
- activesupport (6.0.3.5) lib/active_support/callbacks.rb:121:in `block in run_callbacks’
- activesupport (6.0.3.5) lib/active_support/callbacks.rb:139:in `run_callbacks’
- actionpack (6.0.3.5) lib/abstract_controller/callbacks.rb:41:in `process_action’
- actionpack (6.0.3.5) lib/action_controller/metal/rescue.rb:22:in `process_action’
- actionpack (6.0.3.5) lib/action_controller/metal/instrumentation.rb:33:in `block in process_action’
- activesupport (6.0.3.5) lib/active_support/notifications.rb:180:in `block in instrument’
- activesupport (6.0.3.5) lib/active_support/notifications/instrumenter.rb:24:in `instrument’
- activesupport (6.0.3.5) lib/active_support/notifications.rb:180:in `instrument’
- actionpack (6.0.3.5) lib/action_controller/metal/instrumentation.rb:32:in `process_action’
- actionpack (6.0.3.5) lib/action_controller/metal/params_wrapper.rb:245:in `process_action’
- activerecord (6.0.3.5) lib/active_record/railties/controller_runtime.rb:27:in `process_action’
- actionpack (6.0.3.5) lib/abstract_controller/base.rb:136:in `process’
- actionview (6.0.3.5) lib/action_view/rendering.rb:39:in `process’
- rack-mini-profiler (2.3.1) lib/mini_profiler/profiling_methods.rb:111:in `block in profile_method’
- actionpack (6.0.3.5) lib/action_controller/metal.rb:190:in `dispatch’
- actionpack (6.0.3.5) lib/action_controller/metal.rb:254:in `dispatch’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:50:in `dispatch’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:33:in `serve’
- actionpack (6.0.3.5) lib/action_dispatch/journey/router.rb:49:in `block in serve’
- actionpack (6.0.3.5) lib/action_dispatch/journey/router.rb:32:in `each’
- actionpack (6.0.3.5) lib/action_dispatch/journey/router.rb:32:in `serve’
- actionpack (6.0.3.5) lib/action_dispatch/routing/route_set.rb:834:in `call’
- lib/middleware/omniauth_bypass_middleware.rb:68:in `call’
- rack (2.2.3) lib/rack/tempfile_reaper.rb:15:in `call’
- rack (2.2.3) lib/rack/conditional_get.rb:27:in `call’
- rack (2.2.3) lib/rack/head.rb:12:in `call’
- lib/content_security_policy/middleware.rb:12:in `call’
- lib/middleware/anonymous_cache.rb:355:in `call’
- rack (2.2.3) lib/rack/session/abstract/id.rb:266:in `context’
- rack (2.2.3) lib/rack/session/abstract/id.rb:260:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/cookies.rb:648:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/callbacks.rb:27:in `block in call’
- activesupport (6.0.3.5) lib/active_support/callbacks.rb:101:in `run_callbacks’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/callbacks.rb:26:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/actionable_exceptions.rb:18:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/debug_exceptions.rb:32:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/show_exceptions.rb:33:in `call’
- logster (2.9.6) lib/logster/middleware/reporter.rb:43:in `call’
- railties (6.0.3.5) lib/rails/rack/logger.rb:37:in `call_app’
- railties (6.0.3.5) lib/rails/rack/logger.rb:28:in `call’
- config/initializers/100-quiet_logger.rb:23:in `call’
- config/initializers/100-silence_logger.rb:31:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/remote_ip.rb:81:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/request_id.rb:27:in `call’
- lib/middleware/enforce_hostname.rb:23:in `call’
- rack (2.2.3) lib/rack/method_override.rb:24:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/executor.rb:14:in `call’
- rack (2.2.3) lib/rack/sendfile.rb:110:in `call’
- actionpack (6.0.3.5) lib/action_dispatch/middleware/host_authorization.rb:76:in `call’
- rack-mini-profiler (2.3.1) lib/mini_profiler/profiler.rb:373:in `call’
- message_bus (3.3.4) lib/message_bus/rack/middleware.rb:61:in `call’
- lib/middleware/request_tracker.rb:177:in `call’
- railties (6.0.3.5) lib/rails/engine.rb:527:in `call’
- railties (6.0.3.5) lib/rails/railtie.rb:190:in `public_send’
- railties (6.0.3.5) lib/rails/railtie.rb:190:in `method_missing’
- rack (2.2.3) lib/rack/urlmap.rb:74:in `block in call’
- rack (2.2.3) lib/rack/urlmap.rb:58:in `each’
- rack (2.2.3) lib/rack/urlmap.rb:58:in `call’
- unicorn (5.8.0) lib/unicorn/http_server.rb:634:in `process_client’
- unicorn (5.8.0) lib/unicorn/http_server.rb:732:in `worker_loop’
- unicorn (5.8.0) lib/unicorn/http_server.rb:548:in `spawn_missing_workers’
- unicorn (5.8.0) lib/unicorn/http_server.rb:144:in `start’
- unicorn (5.8.0) bin/unicorn:128:in `<top (required)>’
- vendor/bundle/ruby/2.7.0/bin/unicorn:23:in `load’
- vendor/bundle/ruby/2.7.0/bin/unicorn:23:in `’
-
我已尝试重新运行 Discourse 设置向导,但问题依然存在。
-
我已尝试在禁用所有插件的安全模式下运行,但问题依然存在。
- 我还尝试将 Discourse 的语言环境设回英语,并在
/sidekiq/scheduler 中触发 Jobs::EnsureDbConsistency,但这些组名称仍然保留为日语。
techAPJ
(Arpit Jalan)
5
:group_name=>“スタッフ”
看起来 group_name 参数未进行 URL 编码。请问您使用的是哪个浏览器?
我在最新版本的 Chrome 上无法复现此问题。
我使用的是最新版的 Chrome 浏览器。
我也尝试了 Firefox 和 Opera,它们都出现了同样的问题。
我发现其他人也遇到了相同的问题。
techAPJ
(Arpit Jalan)
7
我仍然无法复现此问题。在我的环境中,浏览器会按如下方式对链接进行百分号编码:
http://localhost:9292/topics/private-messages-group/arpit/%E3%82%B9%E3%82%BF%E3%83%83%E3%83%95.json
… 服务器随后返回了正确的响应。
techAPJ
(Arpit Jalan)
8
您的浏览器和操作系统默认区域设置是什么?是英语还是日语?
我想知道为什么您的浏览器中没有发生百分比 URL 编码。
我的 Windows 10 已同时安装了日语和中文语言包。
目前,Windows 默认语言设置为中文。
我的 Chrome 浏览器是日语界面,而 Firefox 是英语界面。
经过多次测试,我发现群组名称存在一些奇怪的行为。
例如,在“自定义” → “文本”中,我将
groups.default_names.trust_level_0 设置为 トラストレベル0
此时 URL 变为 /g/%E3%83%88%E3%83%A9%E3%82%B9%E3%83%88%E3%83%AC%E3%83%99%E3%83%AB4/messages,并出现 500 内部服务器错误。
如果我将 groups.default_names.trust_level_0 改回 trust_level_0 并等待一天,URL 会变回 /g/trust_level_0/messages/,页面可以正常访问。
如果我将名称改为其他单词,例如 groups.default_names.trust_level_0 = Level 0 并等待一天,URL 将保持不变。如果原 URL 是日语,则仍为日语;如果是英语,则仍为英语。
目前,我打算将所有群组名称改回英文名称,这样应该能解决问题。群组名称必须与默认的英文名称完全一致,否则 URL 无法恢复为英文。
例如,几天前我将 groups.default_names.admins 设置为 Admin(因为忘记在 Admin 后加 “s”),几天后,URL 仍然保持为日语。
cylau1996
(Lau Chi Yung)
10
我遇到了完全相同的问题。这个问题已经存在一段时间了,在此期间我多次更新了 Discourse。

我已尝试将语言切换为英语和中文(台湾),并分别在 Google Chrome 和 Firefox 浏览器中测试。
sam
(Sam Saffron)
11
我们无法复现此问题,请问需要哪些具体步骤才能触发该情况?
hawm
(Hawm)
12
当我为群组设置 Unicode 名称后,如果禁用“Unicode 用户名”,就会出现这种情况。
cylau1996
(Lau Chi Yung)
13
非常感谢!启用 Unicode 用户名后,我的问题已经解决了。