javascript - 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 代码问题仍然存在。
谢谢
解决方案
这不是一个非常明确的错误消息,但听起来您的错误来自 Xdebug,而不是 PHP。
您可以在此处看到类似的问题。
我会在 PHPStorm 调试选项卡中检查您的“Watches”选项卡,并从 PHPStorm 转到Run > View Breakpoints
并删除所有这些选项卡。为了确保您也可以暂时停用 XDebug(通过php.ini
设置)以确认问题消失。
推荐阅读
- visual-studio - 无法启动程序 https localhost 调试器未正确安装
- node.js - 我部署了我的项目,我收到此错误 Input file contains unsupported image format
- javascript - 根据特定标准查找并合并组合键列表 - Javascript
- c++ - 如何使 VSCode 缩进不带括号的 if 语句?
- python - 为什么我的 python 代码不能用于计算工资?
- automation - 如何自动化 Instagram Reels 调度?是否有任何私有 API 或外部调度代码
- html - 如何在内部标签内显示图像标签?
- javascript - Javascript如何在日期结束时增加月份
- django - 如何将返回函数值存储到变量中以在Django的原始函数中使用
- python - 记录到不同模块中的不同文件