duan39779 2015-12-12 13:59
浏览 119
已采纳

MySQL regexp不检测等号

I got a mysql database that I am trying to find some urls using REGEXP.

However, my regex does not seem to work, right at the equals sign.

An example field would be:

POST /4jEFhi.php?p=o2k8q6j5dm9pau HTTP/1.1 ~~ Host: example.com ~~ User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0)

MY initial regex looks like this:

^POST /(?![a-z_]{6})[A-Za-z0-9_]{6}.php\?[a-z]=[a-z0-9]{10,}

However, in mysql workbench and or phpmyadmin, I face the same problems.

First, this piece:

(?![a-z_]{6})

Does not work in MySQL, I get the following error:

Error Code: 1139. Got error 'repetition-operator operand invalid' from regexp

If I remove it, I seem to be good to continue with

^POST /[A-Za-z0-9_]{6}.php\?[a-z]=[a-z0-9]{10,}

However,The detection seems to stop at the = (equals-sign)

This works, but not as precise:

^POST /(?![a-z_]{6})[A-Za-z0-9_]{6}.php\?[a-z]

Any help correcting this is appreciated, because my googling skills have hit the wall.

  • 写回答

1条回答 默认 最新

  • dongliao9233 2015-12-12 14:49
    关注

    Try:

    SET @`URL`    := 'POST /4jEFhi.php?p=o2k8q6j5dm9pau HTTP/1.1 ~~ Host: example.com ~~ User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.1; Trident/4.0)',
        @`REGEXP` := '^POST /[A-Za-z0-9_]{6}\\.php\\?[a-z]\\=[a-z0-9]{10,}';
    
    SELECT @`URL` REGEXP BINARY @`REGEXP`;
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 java代码写在记事本上后在cmd上运行时无报错但又没生成文件
  • ¥15 关于#python#的问题:在跑ldsc数据整理的时候一直抱这种错误,要么--out识别不了参数,要么--merge-alleles识别不了参数(操作系统-linux)
  • ¥15 PPOCRLabel
  • ¥15 混合键合键合机对准标识
  • ¥100 现在不懂的是如何将当前的相机中的照片,作为纹理贴图,映射到扫描出的模型上
  • ¥15 魔霸ROG7 pro,win11.息屏后会显示黑屏,如图,如何解决?(关键词-重新启动)
  • ¥15 有没有人知道这是哪里出了问题啊?要怎么改呀?
  • ¥200 C++表格文件处理-悬赏
  • ¥15 Windows Server2016本地登录失败
  • ¥15 复合卡卡号轨道写入芯片卡