我一直在努力解决这个过程,所以我可以帮忙。
我目前有一个页面,用户可以使用TinyMCE编辑他的页面。
工作流程基本: 用户进行编辑 - >提交 - > AJAX调用SQL文件 - > db。中的SQL文件更新。
问题在于我必须对输入进行编码/解码,因为当AJAX接收到数据并且拥有&在内容中数据字符串将失败..所以这就是我目前所拥有的:
<script>
$(document).ready(function() {
$('#edit').click(function () {
var content = escape(tinyMCE.activeEditor.getContent());
$.ajax({
url: "AJAX_edit_information.php",
type: "POST",
data: "content="+content,
success: function (msg) {
//alert('blabla..');
}
});
});
});
AJAX_edit_information.php包含一些检查,用于提交数据的代码是:
$inhoud = html_entity_decode(stripslashes($_POST['content']));
$query = "UPDATE informatie SET inhoud='$inhoud' WHERE id='1'";
$result = mysql_query($query);
到目前为止,我测试的大部分内容都有效,除了编码的奇怪字符。
在我提取数据的页面上,我有以下代码:
$query = "SELECT * FROM informatie";
$result = mysql_query($query);
$row = mysql_fetch_array($result);
echo html_entity_decode(stripslashes($row['inhoud']));
当我看到文字时,我会得到一些奇怪的字符:%u0308,%u0301o,%u0301 .. 现在是我的问题,我在我的流程中监督的是什么..谢谢
答案 0 :(得分:5)
我解决了问题..
在声明TinyMCE编辑器时,您有一个选项:
tinyMCE.init({
...
entity_encoding : "raw"
});
此选项控制TinyMCE如何处理实体/字符。可以如下面的编码类型所示设置该值。
有关详细信息,请参阅:http://www.tinymce.com/wiki.php/Configuration:entity_encoding