多余回车引起AMF INVALID_AMF_MESSAGE错误

最近使用PHP写AMF的service,本来好好的代码,忽然间就执行出现错误:
引用

message = "faultCode:INVALID_AMF_MESSAGE faultString:'Invalid AMF message'
'"
name = "Error"
rootCause = (null)

使用Google搜索到这个错误经常是使用某个函数错误导致,比如函数为定义。
另外通过实验,在函数里使用了echo、print等输出函数也会导致这个错误。
仔细观察错误内容,发现在错误信息应该是一个回车或者其他不可显示字符,但是我检查代码没发现有额外的echo之类的输出,不得已把整个类重新写,挨个方法复制进去实验,发现又好用了。通过文本比较,只是PHP脚本结束后多了2个空行:
<?php
...
?>
\n
\n

此时才恍然大悟,原来amfphp其实是把PHP脚本执行后的结果返回,这样的话,PHP文件结尾的2个空行就相当于echo '\n',追加到函数执行结果后面,自然导致AMF消息不正确。

你可能感兴趣的:(PHP,脚本,Google)