input 禁止输入特殊字符的四种实现方式


Posted in Javascript onAugust 24, 2016
<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">昨天项目搜索的时候报错,蛋疼的是生产库中的,看了下日志,原因是用户搜索的时候输入了特殊字符,没办法最快捷的办法是直接把用户输入的数据进行筛选,去掉特殊字符</span>

有些特殊字符传入到后台是会产生错误的 有可能会sql注入,所以从根本上拦截

下面一起探讨下input禁止输入特殊字符的方式:

方式一:拿到value值以后 在你传递之前处理

function stripscript(value) {
var pattern = new RegExp("[`~!@#$^&*()=|{}':;',\\[\\].<>/?~!@#¥……&*()——|{}【】‘;:”“'。,、?]") 
var rs = ""; 
for (var i = 0; i < value.length; i++) {
rs = rs+s.substr(i, 1).replace(pattern, ''); 
} 
return rs;
}

直接调用这个函数即可 。

方式二:从最根本上也就是提示用户输入不了特殊字符

function showKeyPress(evt) {
evt = (evt) ? evt : window.event
return checkSpecificKey(evt.keyCode);
}
function checkSpecificKey(keyCode) {
var specialKey = "[`~!#$^&*()=|{}':;',\\[\\].<>/?~!#¥……&*()——|{}【】‘;:”“'。,、?]‘'";//Specific Key list
var realkey = String.fromCharCode(keyCode);
var flg = false;
flg = (specialKey.indexOf(realkey) >= 0);
if (flg) {
// alert('请勿输入特殊字符: ' + realkey);
return false;
}
return true;
}
document.onkeypress = showKeyPress;

使用:在input控件上加入事件 根本没反应

这个好像有点小问题 中文状态下没反应 不知道怎么回事 所以又找了一种

方式三:onkeyup事件 拿到以后去匹配 跟方式一类似

function ValidateValue(textbox) {
var IllegalString = "[`~!#$^&*()=|{}':;',\\[\\].<>/?~!#¥……&*()——|{}【】‘;:”“'。,、?]‘'";
var textboxvalue = textbox.value;
var index = textboxvalue.length - 1;

var s = textbox.value.charAt(index);

if (IllegalString.indexOf(s) >= 0) {
s = textboxvalue.substring(0, index);
textbox.value = s;
}
}

使用: onkeyup = "ValidateValue(this)" 他会输入以后会立马消失,用户是可以看得到我输入的 只是说输入以后就没了,弊端是连续输入就不会消失了(按住不动)

接下来最牛逼的一种 中和以上方式

方式四:直接在控件上使用正在

// <input /[\W]/g,'') "/[^\d]/g,''))">
// 控制输入框只能输入文字或数字,也可以不允许输入特殊字符 这里不允许输入如下字符: (像 !@#$%^&* 等)<br>

这种方式用户可以看到输入了会立马消失 跟方式三差不多 但连续输入是有效的

下面看下js里面判断输入的字符不可为特殊字符:

一、document.onkeypress事件是当输入一个字符的时候就进行校验,校验时执行函授showKeyPress,返回true的时候可输入,false不可输入。

二、evt = (evt) ? evt : window.event,是按下键盘就产生此事件获得你键入的值(是键盘的keyCode)。

var realkey = String.fromCharCode(keyCode);
String.fromCharCode()方法是把键盘值(keyCode)转换成你真实输入的值。

三、方法specialKey.indexOf(realkey):

.indexOf()是String的方法,字符串的IndexOf()方法搜索在该字符串上是否出现了作为参数传递的字符串,如果找到字符串,则返回字符的起始位置 (0表示第一个字符,1表示第二个字符依此类推)如果说没有找到则返回 -1

四、var specialKey = "#$%\^*\'\"\+";

这里是带转义符的字符串,#、$、%、^、*、'、"、+ 这些符号是特殊符号,其中前面带\的是需要转义的。

如果要在当个文本框中加限制输入特殊符号,用<input type="text" id="name" onkeypress="showKeyPress()">

以上所述是小编给大家介绍的input 禁止输入特殊字符的四种实现方式,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
onclick与listeners的执行先后问题详细解剖
Jan 07 Javascript
ztree获取选中节点时不能进入可视区域出现BUG如何解决
Dec 03 Javascript
select隐藏选中值对应的id,显示其它id的简单实现方法
Aug 25 Javascript
自制微信公众号一键排版工具
Sep 22 Javascript
详解vue-cli本地环境API代理设置和解决跨域
Sep 05 Javascript
解决ng-repeat产生的ng-model中取不到值的问题
Oct 02 Javascript
vue 使用vue-i18n做全局中英文切换的方法
Oct 29 Javascript
apicloud拉起小程序并传递参数的方法示例
Nov 21 Javascript
使用javascript做时间倒数读秒功能的实例
Jan 23 Javascript
解决layui的input独占一行的问题
Sep 10 Javascript
解决vue-router 切换tab标签关闭时缓存问题
Jul 22 Javascript
关于Javascript闭包与应用的详解
Apr 22 Javascript
深入浅析JavaScript中的3DES
Aug 24 #Javascript
jQuery自适应轮播图插件Swiper用法示例
Aug 24 #Javascript
JavaScript lodash常见用法系列小结
Aug 24 #Javascript
EasyUI的doCellTip实现鼠标放到单元格上提示单元格内容
Aug 24 #Javascript
JS实现获取当前URL和来源URL的方法
Aug 24 #Javascript
Bootstrap和Angularjs配合自制弹框的实例代码
Aug 24 #Javascript
总结Javascript中的隐式类型转换
Aug 24 #Javascript
You might like
windows的文件系统机制引发的PHP路径爆破问题分析
2014/07/28 PHP
PHP中的命名空间相关概念浅析
2015/01/22 PHP
详解thinkphp中的volist标签
2018/01/15 PHP
mouse_on_title.js
2006/08/25 Javascript
List the Codec Files on a Computer
2007/06/11 Javascript
javascript 按回车键相应按钮提交事件
2009/11/02 Javascript
JS实现self的resend
2010/07/22 Javascript
js indexOf()定义和用法
2012/10/21 Javascript
js判断屏幕分辨率的代码
2013/07/16 Javascript
JavaScript实现在标题栏上显示当前日期的方法
2015/03/19 Javascript
jquery实现很酷的网页顶部图标下拉菜单效果
2015/08/22 Javascript
详解Angularjs filter过滤器
2016/02/06 Javascript
AngularJS入门教程之AngularJS表达式
2016/04/18 Javascript
深入理解node exports和module.exports区别
2016/06/01 Javascript
Jquery实现上下移动和排序代码
2016/10/17 Javascript
js中开关变量使用实例
2017/02/24 Javascript
vue指令做滚动加载和监听等
2019/05/26 Javascript
Vue3为什么这么快
2020/09/23 Javascript
[02:31]2014DOTA2国际邀请赛2009专访:干爹表现出乎意料 看好DK杀回决赛
2014/07/20 DOTA
Python request设置HTTPS代理代码解析
2018/02/12 Python
pandas pivot_table() 按日期分多列数据的方法
2018/11/16 Python
python多进程读图提取特征存npy
2019/05/21 Python
浅析python表达式4+0.5值的数据类型
2020/02/26 Python
Django与pyecharts结合的实例代码
2020/05/13 Python
浅谈Python程序的错误:变量未定义
2020/06/02 Python
Python闭包及装饰器运行原理解析
2020/06/17 Python
使用HTML5的链接预取功能(link prefetching)给网站提速
2012/12/13 HTML / CSS
泰国第一的化妆品网站:Konvy
2018/02/25 全球购物
波兰家居和花园家具专家:4Home
2019/05/26 全球购物
Myprotein中国网站:欧洲畅销运动营养品牌
2021/02/11 全球购物
户外婚礼策划方案
2014/02/08 职场文书
党的群众路线教育实践活动个人对照检查材料(医生)
2014/11/05 职场文书
中学生自我评价范文
2015/03/03 职场文书
2016年119消防宣传日活动总结
2016/04/05 职场文书
pandas提升计算效率的一些方法汇总
2021/05/30 Python
Java 将PPT幻灯片转为HTML文件的实现思路
2021/06/11 Java/Android