[英]How do i check the copied data against banned inputs when user copy & paste content?
我正在开发一个内部有表单生成器的应用程序来构建表单。 在这种情况下,我考虑了特殊字符“#”和“ []”用于针对表单&进行后端数据处理,因此我也禁止用户为相应字符键入键盘上的按键。 我已经完成了禁止用户输入的操作,但是如果用户从某处复制内容并将其粘贴到应该包含上述字符的位置,则我想在用户粘贴之前检查该数据,以禁止输入。 我的担心是这样,但不知道该怎么办,或者有可能这样做或以其他任何方式解决此问题?
预先感谢您的投入...
防止用户按下不需要的键不是解决此问题的最佳方法。 原则上,您有两个问题域:
1)防止表单中的恶意输入通过网络传播。 最好的方法是使用jQuery Submit()并编写一个验证函数,其中a)清理输入并通过网络发送它,或者b)阻止提交并向用户显示错误消息,而不是输入恶意输入。
2)您必须担心,用户可能会绕过您的表单实现并使用curl
或其他工具来绕过现场验证。 因此,在进一步处理之前,您必须在后端注意对输入进行清理。
$("textarea").bind('paste', function(e) {
var self = this;
setTimeout(function(e) {
var textval=$(self.val());
//Replace the banned keys with your custom
$("textarea").val(textval);
}, 0);
});
尝试这样的事情:
$('#yourTextAreaId').on('paste', function (e) {
pasteContent = e.target.value;
//implement containsSpecialChars function
if(containsSpecialChars(pasteContent)){
e.preventDefault()
}
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.