我有一个MYSQL类,我想让它安全地防止SQL注入,所以我想了一个检查算法。例如:
query("SELECT * FROM xyz WHERE id = @1 AND name = '@2' AND pwd = '@3' AND somenumber = @4", param1, param2, param3, param4) 此正则表达式必须与@1和@4匹配,因此第一个和第四个参数应为整数。
我试过这个:
[^'"]@\d+[^'"]但它并不匹配:
@1,@4,@5正确的表达方式是什么?
提前谢谢你。
发布于 2011-05-18 02:16:29
如果需要@123而不是"@123",请使用
(?<!["'])@\d+(?!['"])您的正则表达式的作用:
[^'"]匹配一个“除字符串‘”以外的任何字符“”;»@\d+匹配一个at符号,与possible[^'"]匹配另一个“除字符串”以外的任何字符“”一样多的数字»因此,它将匹配d@12),@@0@,k@09。..。
https://stackoverflow.com/questions/6034826
复制相似问题