Phoenix 日志中的奇怪错误:运行 MyApp.Endpoint 已终止
Strange error in Phoenix logs: running MyApp.Endpoint terminated
我正在开发的 phoenix 网络应用程序中出现以下错误。这是一个简单的应用程序,只有几个模型和一个页面,其中所有模型创建的表单都以多标签形式添加。
我在日志中收到以下错误,但是在浏览器端一切正常。从日志中我也无法理解哪里出了问题以及如何调试它。
[error] #PID<0.1603.0> running MyApp.Endpoint terminated
Server: localhost:4000 (http)
Request: GET /
** (exit) an exception was raised:
** (Plug.Conn.AlreadySentError) the response was already sent
(plug) lib/plug/conn.ex:428: Plug.Conn.resp/3
(plug) lib/plug/conn.ex:415: Plug.Conn.send_resp/3
(my_app) web/controllers/personal_info_controller.ex:1: MyApp.PersonalInfoController.phoenix_controller_pipeline/2
(my_app) lib/phoenix/router.ex:265: MyApp.Router.dispatch/2
(my_app) web/router.ex:1: MyApp.Router.do_call/2
(my_app) lib/my_app/endpoint.ex:1: MyApp.Endpoint.phoenix_pipeline/1
(my_app) lib/plug/debugger.ex:90: MyApp.Endpoint."call (overridable 3)"/2
(my_app) lib/phoenix/endpoint/render_errors.ex:34: MyApp.Endpoint.call/2
(plug) lib/plug/adapters/cowboy/handler.ex:15: Plug.Adapters.Cowboy.Handler.upgrade/4
(cowboy) src/cowboy_protocol.erl:442: :cowboy_protocol.execute/4
复制响应时会出现此错误 - 当您有一个插件会发送对某些错误的响应(例如,用户未登录)然后从您的控制器发送另一个响应时,通常会发生此错误动作。
如果没有看到您的代码,很难告诉您问题出在哪里。发送响应后,您可以使用 Plug.Conn.halt/1 来防止此错误。
例如
conn
|> send_resp(404, "Post not found")
|> halt
从控制器中移除 plug :action
为我修复了它。根据 https://github.com/phoenixframework/phoenix/issues/888
不再需要它
此解决方案是在 Phoenix/Elixir/Ejabberd - Response already sent error
上提出的
我正在开发的 phoenix 网络应用程序中出现以下错误。这是一个简单的应用程序,只有几个模型和一个页面,其中所有模型创建的表单都以多标签形式添加。
我在日志中收到以下错误,但是在浏览器端一切正常。从日志中我也无法理解哪里出了问题以及如何调试它。
[error] #PID<0.1603.0> running MyApp.Endpoint terminated
Server: localhost:4000 (http)
Request: GET /
** (exit) an exception was raised:
** (Plug.Conn.AlreadySentError) the response was already sent
(plug) lib/plug/conn.ex:428: Plug.Conn.resp/3
(plug) lib/plug/conn.ex:415: Plug.Conn.send_resp/3
(my_app) web/controllers/personal_info_controller.ex:1: MyApp.PersonalInfoController.phoenix_controller_pipeline/2
(my_app) lib/phoenix/router.ex:265: MyApp.Router.dispatch/2
(my_app) web/router.ex:1: MyApp.Router.do_call/2
(my_app) lib/my_app/endpoint.ex:1: MyApp.Endpoint.phoenix_pipeline/1
(my_app) lib/plug/debugger.ex:90: MyApp.Endpoint."call (overridable 3)"/2
(my_app) lib/phoenix/endpoint/render_errors.ex:34: MyApp.Endpoint.call/2
(plug) lib/plug/adapters/cowboy/handler.ex:15: Plug.Adapters.Cowboy.Handler.upgrade/4
(cowboy) src/cowboy_protocol.erl:442: :cowboy_protocol.execute/4
复制响应时会出现此错误 - 当您有一个插件会发送对某些错误的响应(例如,用户未登录)然后从您的控制器发送另一个响应时,通常会发生此错误动作。
如果没有看到您的代码,很难告诉您问题出在哪里。发送响应后,您可以使用 Plug.Conn.halt/1 来防止此错误。
例如
conn
|> send_resp(404, "Post not found")
|> halt
从控制器中移除 plug :action
为我修复了它。根据 https://github.com/phoenixframework/phoenix/issues/888
此解决方案是在 Phoenix/Elixir/Ejabberd - Response already sent error
上提出的