免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2092 | 回复: 5
打印 上一主题 下一主题

我是新手,请问这条替换文本的SHELL为什么没有效果? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-09-18 18:58 |只看该作者 |倒序浏览
20可用积分
find ./home/myweb/www/ -name 'view1.php' | xargs perl -pi -e 's|and id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM $database_product_name)-(SELECT MIN(id) FROM $database_product_name)) + (SELECT MIN(id) FROM $database_product_name)))|)|g'

我想把“/home/myweb/www/ ”下的“view1.php” 文件里的内容“and id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM $database_product_name)-(SELECT MIN(id) FROM $database_product_name)) + (SELECT MIN(id) FROM $database_product_name)))”替换成内容“)”,我执行以后,查看文件源文件,发现并没有被更改到,请问要怎么修改才可以修改到啊;或者有没有其他语句可以达成目标呢?

[ 本帖最后由 ken1984 于 2009-9-18 19:00 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2009-09-18 20:17 |只看该作者

回复 #1 ken1984 的帖子

匹配当中的special character的原因
用单引号括起来应该就可以了

论坛徽章:
0
3 [报告]
发表于 2009-09-18 21:16 |只看该作者
find ./home/myweb/www/ -name 'view1.php' | xargs perl -pi -e 's|'and id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM $database_product_name)-(SELECT MIN(id) FROM $database_product_name)) + (SELECT MIN(id) FROM $database_product_name)))'|)|g'

这样吗?可是还是不行啊,

论坛徽章:
0
4 [报告]
发表于 2009-09-21 16:42 |只看该作者
find ./home/myweb/www/ -name 'view1.php'|xargs sed -i 's:and id >= (SELECT floor( RAND() * ((SELECT MAX(id) FROM $database_product_name)-(SELECT MIN(id) FROM $database_product_name)) + (SELECT MIN(id) FROM $database_product_name))):):g'

论坛徽章:
2
午马
日期:2015-01-27 11:22:392015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2009-09-24 15:50 |只看该作者
这里有一个问题,就是多次出现了可能的特殊转义字符,如grep对*和$敏感,而sed对于 $ * ( )和空格等符号都敏感,不能直接调用。

这里提供一个可行的方案,用sed来替换,这里用单引号引用可以避免一些字符的影响,但对于$*仍然用转义符号来替换。

  1. find ./home/myweb/www/ -name 'view1.php' | xargs  sed s@'and id >= (SELECT floor( RAND() \* ((SELECT MAX(id) FROM \$database_product_name)-(SELECT MIN(id) FROM \$database_product_name)) + (SELECT MIN(id) FROM \$database_product_name)))'@')'@g
复制代码


这里再提供一下perl的版本,可能会转义的比较多,因为对于+-等符号都敏感

  1. find ./home/myweb/www/ -name 'view1.php' | xargs perl -pi -e 's/and id >= \(SELECT floor\( RAND\(\) \* \(\(SELECT MAX\(id\) FROM \$database_product_name\)\-\(SELECT MIN\(id\) FROM \$database_product_name\)\) \+ \(SELECT MIN\(id\) FROM \$database_product_name\)\)\)/)/g'
复制代码

[ 本帖最后由 to407 于 2009-9-24 16:21 编辑 ]

论坛徽章:
0
6 [报告]
发表于 2009-09-24 20:50 |只看该作者

回复 #3 ken1984 的帖子

转移字符要处理一下的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP