做项目时遇到一个问题:页面上文本框中的值中如果有‘+’号不能保存到数据库,被自动筛选掉了。
第一反应就是sql的问题,应该是因为后台写进数据库时sql用的是一般注入的方式,而不是prepareStatement的方式而产生的问题。因为后台用的是myBatis框架,用什么方式我说了不算(注:当然这个肯定是有解决方法的,只是没有去深究,而且关于mybatis用的是不是prepareStatement的方式我也不确定,不过根据我的了解用的应该就是这种方式),只能通过另外的办法来解决问题了。
打开idea,翻看了代码才知道不是SQL的问题,应该是在接收页面传来的字符串时就有了问题。因为在页面上传来时字符串是这种形式a+b,而到了java代码中接收时就变成了String s = a+b了,自然就去掉了中间的加号。
这时同事提醒可以在传参前先URLEncode一下,于是百度,经过测试,找到了一个解决方案:在传参前先把参数encode一下,具体例子如下:
var title = document.getElementById("title");
title = encodeURIComponent(title);
然后再把编码后的title传给后台,就没问题了。
欢迎各位高手交流、指正。