首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >正则表达式问题-搜索a:不带引号的特定模式

正则表达式问题-搜索a:不带引号的特定模式
EN

Stack Overflow用户
提问于 2011-05-18 01:39:06
回答 1查看 68关注 0票数 2

我有一个MYSQL类,我想让它安全地防止SQL注入,所以我想了一个检查算法。例如:

代码语言:javascript
运行
复制
query("SELECT * FROM xyz WHERE id = @1 AND name = '@2' AND pwd = '@3' AND somenumber = @4", param1, param2, param3, param4) 

此正则表达式必须与@1和@4匹配,因此第一个和第四个参数应为整数。

我试过这个:

代码语言:javascript
运行
复制
[^'"]@\d+[^'"]

但它并不匹配:

代码语言:javascript
运行
复制
@1,@4,@5

正确的表达方式是什么?

提前谢谢你。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-05-18 02:16:29

如果需要@123而不是"@123",请使用

代码语言:javascript
运行
复制
(?<!["'])@\d+(?!['"])

您的正则表达式的作用:

  • [^'"]匹配一个“除字符串‘”以外的任何字符“”;»
  • @\d+匹配一个at符号,与possible
  • [^'"]匹配另一个“除字符串”以外的任何字符“”一样多的数字»

因此,它将匹配d@12),@@0@,k@09。..。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6034826

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档