//药品搜索
@RequestMapping(value = "/search")
public ModelAndView search(HttpServletRequest arg0,
HttpServletResponse arg1) throws Exception{
String name = arg0.getParameter("name");
//将得到的值进行编码转换
String transformName = java.net.URLDecoder.decode(name, "UTF-8");
if(name == null){
return new ModelAndView("redirect:/medicine/index");
}
List<Medicine> medicineList = medicineBiz.selectByMedicinename(transformName);
HashMap<String,Object> map = new HashMap<String,Object>();
map.put("title", transformName);
map.put("medicineList",medicineList);
return new ModelAndView("/WEB-INF/tinywebsiteviews/searchgoods",map);
}
//对后台java程序里的name赋值的时候,本身已经使用了一次解码,不过解码的结果依然不对。所以我们可以在页面 上进行两次编码操作,这样后台自动的那次就可以抵消掉一次,然后在使用 searchtext=java.net.URLDecoder.decode(name,"UTF-8");进行一次 解码就好了
function toSearch(){
var val = document.getElementById("search").value;
if(check() == true){
window.location.href="${pageContext.request.contextPath}/medicine/search?name="+encodeURI(encodeURI(val));
}
}
本文介绍了一种解决药品搜索功能中出现的中文乱码问题的方法。通过在前端进行两次编码,在后端进行一次解码,实现了正确展示中文名称的药品搜索结果。
1万+

被折叠的 条评论
为什么被折叠?



