PHP---ajax传递POST值(包含html标记)到提交页面数据丢失或乱码
程序员文章站
2022-05-15 19:37:38
...
问题
??通过获取文本编辑器中的内容(一个html文本),然后采用ajax通过POST将文本内容传递到后台,保存为xxx.html文件,但是到浏览器中去打开这个文件会出现数据丢失或者乱码。
原因
??这是因为文本中带了html标记,在用POST传递值的时候,值的内容中带了‘&’等一些字符会影响变量的值的提取,导致乱码或者丢失数据。
解决办法
??将待传递的html文本内容进行编码,然后传递过去。再通过浏览器的自动解码即可。
编码函数
??encodeURIComponent() 函数可把字符串作为 URI 组件进行编码。该方法不会对 ASCII 字母和数字进行编码,也不会对这些 ASCII 标点符号进行编码: - _ . ! ~ * ’ ( ) 。
其他字符(比如 :;/?:@&=+$,# 这些用于分隔 URI 组件的标点符号),都是由一个或多个十六进制的转义序列替换的。如果 URI 组件中含有分隔符,比如 ? 和 #,则应当使用 encodeURIComponent() 方法分别对各组件进行编码,其他则可以使用encodeURI(URIstring)函数来编码。
var content = UM.getEditor('myEditor').getAllHtml();
/*对待传递的值的内容进行编码*/var htmlcontent = encodeURIComponent(content);
alert(htmlcontent);
var postStr = 'news_title=' + news_title +'&htmlc/span> + htmlcontent + '&sid='+Math.random();
alert(postStr);
ajax("../news_submit_hand.php",postStr,function(result){if(result == 'submit_success'){
alert("新闻提交成功!请通过右上角的关闭按钮来关闭编辑器。");
}
else {
alert("新闻提交出错!");
}
});
编码之后还需要解决的问题
??新闻提交中传进了一个标题,要将标题插入到html文本内容的正文之前,则需要在标记的后面插入标题。此时编码后变为了%3Cbody%3E。则有解决思路:
??首先通过%3Cbody%3E字符串从指定位置处将原字符串分割成两个字符串,然后再将分割的前半部分字符串+待插入的字符串+后半部分字符串,形成新的字符串,这样就实现了功能;
??代码实现:
functionstr_insert($str, $i, $substr)
{for($j=0; $j$i