首页 > 解决方案 > Symfony v2.8 响应($message)方法“返回”超出预期

问题描述

我的目标是向我的网页返回一条消息,并在其中显示它,但返回的值不仅包含消息,还包含错误页面的消息和 html 代码!

这是 Symfony 捆绑操作路由和函数定义:

/**
 * @Route("/Utilities/getMessages/{callSign}/{loginDateTime}",
 *        defaults={"callSign"="","loginDateTime"=""})
 *
 * @return:     json string.
 *
 */

public function getMessagesAction( $callSign, $loginDateTime ) { ... }

我正在使用以下代码将消息结果返回给 ajax 调用:

由 Ajax 调用调用的服务器端 PHP 代码...

$message = 'Some message to be displayed.';

// Return to the page and display the message ...

return new Response( $message );  // Inspecting $message shows only
                                  // 'Some message to be displayed.'

调用上述代码并接收响应的客户端 JavaScript 代码:

$.ajax( { // Send form data to the same page that the page came from
          type:        'POST',
          data:        data,
          cache:       false,
          async:       true,
          contentType: false,
          enctype:     'multipart/form-data',
          processData: false
        } )
.done( function( data, textStatus, jqXHR ) { ... } // Inspecting data
                                                    // shows more than
                                                    // 'Some ...
.fail( function( jqXHR, textStatus, errorThrown ) { ... }

return new Response( $message );在函数的第一个可执行行设置断点.done(...)时,PHP 脚本执行到达return new Response( $message );语句处的断点而没有任何错误,我可以看到参数的值是“要显示的一些消息。”,正如预期的那样,但是在.done()函数的第一行暂停时,数据参数的值为: Some message to be 'displayed.<!DOCTYPE html><html>...</html>

如果将 html 代码放在一个文件中并加载到浏览器中,它看起来有点像这样:

Whoops, looks like something went wrong.
1/1 FatalErrorException in debug-eval(1) : eval()'d code line 1:
Parse Error: syntax error, unexpected ')'
in debug-eval(1) : eval()'d code line 1

一条明显的错误消息,但我的代码没有使用任何可能失败的 eval() 语句,并且执行到 Response 语句时没有任何错误。这是 Symfony 响应语句方法/函数中的错误吗?如果没有,我怎样才能找出真正发生的事情,以便修复它?

跟进

更改服务器端代码以对 json 字符串进行编码,然后在客户端对其进行解码并没有帮助。

服务器端 PHP 代码:

// Return to the login page and display the message ...

// $message'value => '{ "message":"' . $message . '"}';

$message = json_encode( [ 'message' => $message ] ); 
return new Response( $message );

客户端Javascript:

    ***unchaged***

在这种情况下,我仍在检查 data 参数,但它现在包含 json 编码消息和 html 错误页面代码。将此输入JSON.parse( data );语句以将 json 数据转换为 javaScript 对象会导致 javaScript 冻结。这不是 json 问题,附加到我的消息末尾的 html 代码问题仍然存在。

谢谢

标签: javascriptphpajaxresponsesymfony-2.8

解决方案


这不是一个非常明确的错误消息,但听起来您的错误来自 Xdebug,而不是 PHP。

您可以在此处看到类似的问题。

我会在 PHPStorm 调试选项卡中检查您的“Watches”选项卡,并从 PHPStorm 转到Run > View Breakpoints并删除所有这些选项卡。为了确保您也可以暂时停用 XDebug(通过php.ini设置)以确认问题消失。


推荐阅读