首页 > 后端开发 > php教程 > 神奇的%EF%BB%BF解决方法

神奇的%EF%BB%BF解决方法

WBOY
发布: 2016-06-13 12:00:54
原创
4737 人浏览过

神奇的%EF%BB%BF
废话不多说上代码:
前台:

<br />function on_post_form(){<br />	var f = document.post_myform;<br />	var s_paramName = document.getElementById("select_paramName").value;<br />        f.action = "__APP__/index/select_infomessage-s_paramName-"+encodeURIComponent(s_paramName)+".html";<br />        f.submit();<br />}<br /><input name="select_paramName" class="KeyWord" id="select_paramName" size="20" maxlength="30" type="text"><br /><div id="searchresult" style="display: none;"></div><br />
登录后复制

<br />$(document).ready(function(){<br /> $('#select_paramName').keyup(function(){   //输入框的id为search,这里监听输入框的keyup事件<br />  $.ajax({<br />     type:"GET",     //AJAX提交方式为GET提交<br />	   url:"__APP__/index/get_search_showdiv",   //处理页的URL地址<br />	   data:"s_Name="+encodeURIComponent($('#select_paramName').val()),   //要传递的参数<br />	   success:function(data){   //成功后执行的方法<br />	      if(data != ""){<br />				var ss;<br />				ss = data.split("@");   //分割返回的字符串<br />				var layer;<br />				layer = "<table>";     //创建一个table<br />				for(var i=0;i<ss.length-1;i++){<br />				 layer += "<tr><td class='line'>"+ss[i]+"</td></tr>";<br />				}<br />				layer += "</table>";<br />				$('#searchresult').empty();  //先清空#searchresult下的所有子元素<br />				$('#searchresult').append(layer);//将刚才创建的table插入到#searchresult内<br />				$("#searchresult").css("display", "");<br />				$('.line').hover(function(){  //监听提示框的鼠标悬停事件<br />				 $(this).addClass("hover"); <br />				},function(){<br />				 $(this).removeClass("hover");<br />				});<br />				$('.line').click(function(){  //监听提示框的鼠标单击事件<br />				 $('#select_paramName').val($(this).text());<br />				 $("#searchresult").css("display", "none"); <br />				 ChangeCoords();<br />				});<br />			   }else{<br />				$('#searchresult').empty();<br />			   }<br />	   }<br />  });<br /> });<br />});<br />
登录后复制


后台:
<br />public function get_search_showdiv()<br />	{<br />	   //urlencode urldecode 文本框自动提示<br />	   $keyword = urldecode($_GET['s_Name']);<br />	   $condition = "f_hotname like '%".$keyword."%'";<br />	   $info=$this->model->table('forest')->field('f_hotname')->where($condition)->order('f_id desc')->limit(5)->select();<br />	   if($keyword !=""){<br />		   foreach($info as $vo)     <br />		   {      <br />			 echo $vo['f_hotname'].'@';    <br />		   } <br />	   }else{<br />	       <br />		   echo "";<br />	   }<br />	}<br />
登录后复制


问题症状:比如输入“百度”    
在div   #searchresult   里显示:
百度杀毒
百度卫士
百度影音

如果选择第一项百度杀毒,火狐浏览器这样显示:
http://192.168.1.101/index/select_infomessage-s_paramName-%EF%BB%BF%百度杀毒.html
什么也没有。。。
如果选择第二项百度卫士,火狐浏览器这样显示:
http://192.168.1.101/index/select_infomessage-s_paramName-百度卫士.html
正常搜索,可以搜索到信息。其它项也是正常,唯独第一项就不正常。

度娘说是bom头,我所有页面都是去bom头的,编码也是utf8,尝试了很多也解决不了问题。
为什么会在第一项时候会加入%EF%BB%BF%,,,,, 在其它项都可以正常显示的。


------解决方案--------------------
public function get_search_showdiv()
这个函数所在php脚本文件有BOM
------解决方案--------------------
utf-8 文件的 BOM 头的十六进制表示是 EFBBBF
url 编码后是 %EF%BB%BF

ajax 请求的 url 为 __APP__/index/get_search_showdiv
显然这是在使用框架

框架在处理一个请求时,至少会加载 3 个文件
所以任何一个被加载的文件有 BOM 头,返回的内容就会有 BOM 头

连接变成 ....%EF%BB%BF百度杀毒.html
而不是 ....%EF%BB%BF%EF%BB%BF百度杀毒.html
就表示只有一个文件有 BOM 头

ajax 收到的是形如 [email protected]@xxx@ 的串
BOM 当然是附加在内容前面的: [email protected]@xxx@
拆分成数组后,自然是只有第一项有 BOM 啦

相关标签:
来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板