dqx76962 2016-12-20 17:31
浏览 56

PHP正则表达式排除任何字符自定义查询

I'm using a database merging utility for wordpress called Mergebot. One of the tools it includes, is Query Exclusion. This basically excludes certain db queries from being tracked.

I have to use PHP regex to identify the data I'd like to exclude . Example from the docs:

For example let’s say you want to exclude a plugin’s settings from the options table in WordPress (that has the option_name "my_custom_plugin"). The field values would be as follows:

Table: options

Column: option_name

Search: my_custom_plugin

I need to exclude any queries that affect the mm_sessions table, which uses the column id as the primary key. So my current exclusion (which isn't working) looks like this:

Table: sessions

Column: id

Search: [\s\S]

Example query that should be excluded:

UPDATE `mm_sessions` SET `data` = 'YToxOntzOjEwOiJtbV9wcmV2aWV3IjtzOjQxOTA6Ik86MTA6Ik1NX1ByZXZpZXciOjU6e3M6MjI6IgBNTV9QcmV2aWV3AGFjY2Vzc1RhZ3MiO2E6MDp7fXM6MTY6IgBNTV9QcmV2aWV3AHVzZXIiO086NzoiTU1fVXNlciI6NzY6e3M6MjE6IgBNTV9Vc2VyAG1lbWJlcnNoaXBJZCI7aToxO3M6MTU6IgBNTV9Vc2VyAHN0YXR1cyI7czoxOiIxIjtzOjIyOiIATU1fVXNlcgBwZW5kaW5nU3RhdHVzIjtzOjE6IjAiO3M6MjE6IgBNTV9Vc2VyAGltcG9ydGVkRmxhZyI7czoxOiIwIjtzOjI0OiIATU1fVXNlcgBsYXN0VXBkYXRlZERhdGUiO047czoyNjoiAE1NX1VzZXIAc3RhdHVzVXBkYXRlZERhdGUiO047czoyMjoiAE1NX1VzZXIAc3RhdHVzTWVzc2FnZSI7czowOiIiO3M6MjM6IgBNTV9Vc2VyAGRheXNDYWxjTWV0aG9kIjtzOjk6ImpvaW5fZGF0ZSI7czoyMjoiAE1NX1VzZXIAZGF5c0NhbGNWYWx1ZSI7czowOiIiO3M6MjU6IgBNTV9Vc2VyAGJlY2FtZUFjdGl2ZURhdGUiO047czoxNDoiAE1NX1VzZXIAcGhvbmUiO3M6MTQ6Iig1NTUpIDU1NS01NTU1IjtzOjE3OiIATU1fVXNlcgB1c2VybmFtZSI7czoxNDoic2FtcGxldXNlcm5hbWUiO3M6MTQ6IgBNTV9Vc2VyAGVtYWlsIjtzOjE1OiJzYW1wbGVAdGVzdC5jb20iO3M6MTg6IgBNTV9Vc2VyAGZpcnN0TmFtZSI7czo1OiJBZG1pbiI7czoxNzoiAE1NX1VzZXIAbGFzdE5hbWUiO3M6NDoiVGVzdCI7czoyNToiAE1NX1VzZXIAcmVnaXN0cmF0aW9uRGF0ZSI7czoxOToiMjAxNi0xMC0wMiAwMDozODo1NCI7czoyNToiAE1NX1VzZXIAY2FuY2VsbGF0aW9uRGF0ZSI7TjtzOjIzOiIATU1fVXNlcgBleHBpcmF0aW9uRGF0ZSI7TjtzOjE0OiIATU1fVXNlcgBub3RlcyI7czowOiIiO3M6MjU6IgBNTV9Vc2VyAHN1YnNjcmliZWRMaXN0SWQiO3M6MDoiIjtzOjI5OiIATU1fVXNlcgBzdWJzY3JpYmVkUHJvdmlkZXJJZCI7czowOiIiO3M6MjI6IgBNTV9Vc2VyAGxhc3RMb2dpbkRhdGUiO047czoyNzoiAE1NX1VzZXIAbGFzdExvZ2luSXBBZGRyZXNzIjtzOjA6IiI7czoxOToiAE1NX1VzZXIAbG9naW5Db3VudCI7aTotMTtzOjI0OiIATU1fVXNlcgBwYWdlQWNjZXNzQ291bnQiO2k6LTE7czoxOToiAE1NX1VzZXIAZW1haWxDb3VudCI7aTotMTtzOjI5OiIATU1fVXNlcgB3ZWxjb21lRW1haWxTZW50RGF0ZSI7TjtzOjIzOiIATU1fVXNlcgBiaWxsaW5nQWRkcmVzcyI7czoxMjoiMTIzIEZha2UgU3QuIjtzOjIwOiIATU1fVXNlcgBiaWxsaW5nQ2l0eSI7czo3OiJOb3doZXJlIjtzOjIxOiIATU1fVXNlcgBiaWxsaW5nU3RhdGUiO3M6MjoiVFgiO3M6MTk6IgBNTV9Vc2VyAGJpbGxpbmdaaXAiO3M6NToiNTU1NTUiO3M6MjM6IgBNTV9Vc2VyAGJpbGxpbmdDb3VudHJ5IjtzOjI6IlVTIjtzOjI0OiIATU1fVXNlcgBzaGlwcGluZ0FkZHJlc3MiO3M6MTI6IjEyMyBGYWtlIFN0LiI7czoyMToiAE1NX1VzZXIAc2hpcHBpbmdDaXR5IjtzOjc6Ik5vd2hlcmUiO3M6MjI6IgBNTV9Vc2VyAHNoaXBwaW5nU3RhdGUiO3M6MjoiVFgiO3M6MjA6IgBNTV9Vc2VyAHNoaXBwaW5nWmlwIjtzOjU6IjU1NTU1IjtzOjI0OiIATU1fVXNlcgBzaGlwcGluZ0NvdW50cnkiO3M6MjoiVVMiO3M6MjI6IgBNTV9Vc2VyAHRvdGFsUGF5bWVudHMiO2k6MDtzOjIxOiIATU1fVXNlcgB0b3RhbFJlZnVuZHMiO2k6MDtzOjI3OiIATU1fVXNlcgBmb3Jnb3RQYXNzd29yZEhhc2giO047czoxOToiAE1NX1VzZXIAbWVtYmVyc2hpcCI7TzoxODoiTU1fTWVtYmVyc2hpcExldmVsIjoyMzp7czozMjoiAE1NX01lbWJlcnNoaXBMZXZlbABlbWFpbFN1YmplY3QiO3M6MDoiIjtzOjI5OiIATU1fTWVtYmVyc2hpcExldmVsAGVtYWlsQm9keSI7czowOiIiO3M6MzI6IgBNTV9NZW1iZXJzaGlwTGV2ZWwAcmVmZXJlbmNlS2V5IjtzOjA6IiI7czoyNDoiAE1NX01lbWJlcnNoaXBMZXZlbABuYW1lIjtzOjA6IiI7czozNjoiAE1NX01lbWJlcnNoaXBMZXZlbABkZWZhdWx0UHJvZHVjdElkIjtzOjA6IiI7czozMDoiAE1NX01lbWJlcnNoaXBMZXZlbABpc0ZyZWVGbGFnIjtzOjE6IjEiO3M6MzM6IgBNTV9NZW1iZXJzaGlwTGV2ZWwAaXNEZWZhdWx0RmxhZyI7czoxOiIwIjtzOjMxOiIATU1fTWVtYmVyc2hpcExldmVsAGRlc2NyaXB0aW9uIjtzOjA6IiI7czozMDoiAE1NX01lbWJlcnNoaXBMZXZlbABwcm9kdWN0SWRzIjthOjA6e31zOjM0OiIATU1fTWVtYmVyc2hpcExldmVsAGxhc3RQcm9kdWN0SWRzIjthOjA6e31zOjMxOiIATU1fTWVtYmVyc2hpcExldmVsAGNhdGVnb3J5SWRzIjthOjA6e31zOjI2OiIATU1fTWVtYmVyc2hpcExldmVsAHN0YXR1cyI7czoxOiIxIjtzOjMxOiIATU1fTWVtYmVyc2hpcExldmVsAGVtYWlsRnJvbUlkIjtzOjA6IiI7czoyNzoiAE1NX01lbWJlcnNoaXBMZXZlbABidW5kbGVzIjtzOjA6IiI7czoyNzoiAE1NX01lbWJlcnNoaXBMZXZlbABleHBpcmVzIjtzOjE6IjAiO3M6MzI6IgBNTV9NZW1iZXJzaGlwTGV2ZWwAZXhwaXJlQW1vdW50IjtzOjA6IiI7czozMjoiAE1NX01lbWJlcnNoaXBMZXZlbABleHBpcmVQZXJpb2QiO3M6MDoiIjtzOjM5OiIATU1fTWVtYmVyc2hpcExldmVsAHdlbGNvbWVFbWFpbEVuYWJsZWQiO3M6MToiMSI7czoyNjoiAE1NX01lbWJlcnNoaXBMZXZlbAB3cFJvbGUiO3M6MTQ6Im1tLWlnbm9yZS1yb2xlIjtzOjU6IgAqAGlkIjtpOjA7czoxNjoiAE1NX0VudGl0eQB2YWxpZCI7YjowO3M6MTg6IgBNTV9FbnRpdHkAYXV0aEtleSI7czowOiIiO3M6MTc6IgAqAG5vdGlmeVNlcnZpY2VzIjtiOjE7fXM6MjU6IgBNTV9Vc2VyAGxhc3RNZW1iZXJzaGlwSWQiO3M6MDoiIjtzOjI3OiIATU1fVXNlcgBsYXN0TWVtYmVyc2hpcE5hbWUiO3M6MDoiIjtzOjI3OiIATU1fVXNlcgBsYXN0RGF5c0NhbGNNZXRob2QiO3M6MDoiIjtzOjI2OiIATU1fVXNlcgBsYXN0RGF5c0NhbGNWYWx1ZSI7czowOiIiO3M6Mjk6IgBNTV9Vc2VyAGxhc3RDYW5jZWxsYXRpb25EYXRlIjtzOjA6IiI7czoyNzoiAE1NX1VzZXIAbGFzdEV4cGlyYXRpb25EYXRlIjtzOjA6IiI7czoyMjoiAE1NX1VzZXIAbGFzdEZpcnN0TmFtZSI7czowOiIiO3M6MjE6IgBNTV9Vc2VyAGxhc3RMYXN0TmFtZSI7czowOiIiO3M6MTg6IgBNTV9Vc2VyAGxhc3RFbWFpbCI7czoyNjoiYWRtaW5Ac3BvcnRzYmV0dGluZ21heC5jb20iO3M6MjE6IgBNTV9Vc2VyAGxhc3RVc2VybmFtZSI7czoyNjoiYWRtaW5Ac3BvcnRzYmV0dGluZ21heC5jb20iO3M6MTg6IgBNTV9Vc2VyAGxhc3RQaG9uZSI7czowOiIiO3M6MTg6IgBNTV9Vc2VyAGxhc3ROb3RlcyI7czowOiIiO3M6MTk6IgBNTV9Vc2VyAGxhc3RTdGF0dXMiO3M6MDoiIjtzOjIzOiIATU1fVXNlcgBsYXN0U3RhdHVzTmFtZSI7czowOiIiO3M6Mjc6IgBNTV9Vc2VyAGxhc3RCaWxsaW5nQWRkcmVzcyI7czowOiIiO3M6MjQ6IgBNTV9Vc2VyAGxhc3RCaWxsaW5nQ2l0eSI7czowOiIiO3M6MjU6IgBNTV9Vc2VyAGxhc3RCaWxsaW5nU3RhdGUiO3M6MDoiIjtzOjIzOiIATU1fVXNlcgBsYXN0QmlsbGluZ1ppcCI7czowOiIiO3M6Mjc6IgBNTV9Vc2VyAGxhc3RCaWxsaW5nQ291bnRyeSI7czowOiIiO3M6Mjg6IgBNTV9Vc2VyAGxhc3RTaGlwcGluZ0FkZHJlc3MiO3M6MDoiIjtzOjI1OiIATU1fVXNlcgBsYXN0U2hpcHBpbmdDaXR5IjtzOjA6IiI7czoyNjoiAE1NX1VzZXIAbGFzdFNoaXBwaW5nU3RhdGUiO3M6MDoiIjtzOjI0OiIATU1fVXNlcgBsYXN0U2hpcHBpbmdaaXAiO3M6MDoiIjtzOjI4OiIATU1fVXNlcgBsYXN0U2hpcHBpbmdDb3VudHJ5IjtzOjA6IiI7czoyMjoiAE1NX1VzZXIAc3RhdHVzVXBkYXRlZCI7YjowO3M6Mjk6IgBNTV9Vc2VyAHNlbmRXZWxjb21lRW1haWxGbGFnIjtiOjE7czozNToiAE1NX1VzZXIAbWVtYmVyc2hpcExldmVsQ2hhbmdlZEZsYWciO2I6MTtzOjMxOiIATU1fVXNlcgBsYXN0Rm9yZ290UGFzc3dvcmRIYXNoIjtOO3M6MjY6IgBNTV9Vc2VyAG9yaWdpbkFmZmlsaWF0ZUlkIjtzOjA6IiI7czoyOToiAE1NX1VzZXIAb3JpZ2luU3ViYWZmaWxpYXRlSWQiO3M6MDoiIjtzOjIwOiIATU1fVXNlcgBpc0NTVkltcG9ydCI7YjowO3M6NToiACoAaWQiO2k6MTc2O3M6MTY6IgBNTV9FbnRpdHkAdmFsaWQiO2I6MTtzOjE4OiIATU1fRW50aXR5AGF1dGhLZXkiO3M6MDoiIjtzOjE3OiIAKgBub3RpZnlTZXJ2aWNlcyI7YjoxO31zOjE2OiIATU1fUHJldmlldwBkYXlzIjtpOjA7czoyNDoiAE1NX1ByZXZpZXcAbWVtYmVyVHlwZUlkIjtpOjA7czoyODoiAE1NX1ByZXZpZXcAYWNjZXNzVGFnQXBwbGllZCI7Tjt9Ijt9', `ip_address` = '127.0.0.1', `expiration_date` = '2016-12-20 18:50:19' WHERE `id` = '4b9cde7778be602befd455f194c38d44';

I believe the issue i'm encountering has to do with how I'm applying the regex syntax as it relates to the data in the db columns. Any ideas on how to properly format the regex so it identifies if any characters exist in the ID column, then exclude that query?

EDIT: I should also add that the docs specifically state to not include the table prefix when adding the exclusion; hence me using sessions instead of mm_sessions

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 python的qt5界面
    • ¥15 无线电能传输系统MATLAB仿真问题
    • ¥50 如何用脚本实现输入法的热键设置
    • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
    • ¥30 深度学习,前后端连接
    • ¥15 孟德尔随机化结果不一致
    • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
    • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
    • ¥15 谁有desed数据集呀
    • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100