【转载源码】【powershell】禁用chrome (请停用以开发者模式运行的扩展程序) 的警告
本帖最后由 os51 于 2017-8-5 08:30 编辑来源:https://stackoverflow.com/a/30361260
使用方法:在chrome.dll同目录运行
<# :
@echo off
copy/b "%~f0" "%temp%\%~n0.ps1" >nul
powershell -v 2 -ep bypass -noprofile "%temp%\%~n0.ps1" "'%cd% '" "'%~1'"
del "%temp%\%~n0.ps1"
echo: & pause
exit /b
#>
param($cwd='.', $dll)
function main {
write-host -f white -b black `
"Chrome 'developer mode extensions' warning disabler 20170328"
$pathsDone = @{}
if ($dll -and (gi -literal $dll)) {
doPatch "DRAG'n'DROPPED" ((gi -literal $dll).directoryName + '\')
exit
}
doPatch 'CURRENT DIRECTORY' ((gi -literal $cwd).fullName + '\')
('HKLM', 'HKCU') | %{ $hive = $_
('', '\Wow6432Node') | %{
$key = "${hive}:\SOFTWARE$_\Google\Update\Clients"
gci -ea silentlycontinue $key -r | gp | ?{ $_.CommandLine } | %{
$path = $_.CommandLine -replace '"(.+?\\\d+\.\d+\.\d+\.\d+\\).+', '$1'
if (!$pathsDone[$path.toLower()]) {
doPatch REGISTRY $path
$pathsDone[$path.toLower()] = $true
}
}
}
}
}
function doPatch($pathLabel, $path) {
$dll = Join-Path $path chrome.dll
if (!(Test-Path -literal $dll)) {
return
}
''
$localAppData = ::GetFolderPath('LocalApplicationData')
"$pathLabel $((split-path $dll).Replace($localAppData, '%LocalAppData%'))"
"`tREADING Chrome.dll..."
$bin = ::OpenRead($dll)
$bytes = $bin.ReadBytes(1MB)
# process PE headers
$BC =
$coff = $BC::ToUInt32($bytes,0x3C) + 4
$is64 = $BC::ToUInt16($bytes,$coff) -eq 0x8664
$opthdr = $coff+20
$codesize = $BC::ToUInt32($bytes,$opthdr+4)
$imagebase32 = $BC::ToUInt32($bytes,$opthdr+28)
# patch the flag in data section
$bin.BaseStream.Position = $codesize
$data = $BC::ToString($bin.ReadBytes($bin.BaseStream.Length - $codesize))
$bin.Close()
$flag = 'ExtensionDeveloperModeWarning'
$stroffs = $data.IndexOf($BC::ToString($flag))
if ($stroffs -lt 0) {
write-host -f red "`t$flag not found"
return
}
if ($data.substring($stroffs-3, 2) -eq '00') {
write-host -f darkgreen "`tALREADY PATCHED"
return
}
$stroffs = $stroffs/3 - 1 + $codesize
$centbrowser = $data.indexOf($BC::ToString('CentBrowser')) -gt 0
$EA = $ErrorActionPreference
$ErrorActionPreference = 'silentlyContinue'
$exe = join-path (split-path $path) chrome.exe
while ((get-process chrome -module | ?{ $_.FileName -eq $exe })) {
forEach ($timeout in 15..0) {
write-host -n -b yellow -f black `
"`rChrome is running and will be terminated in $timeout sec. "
write-host -n -b yellow -f darkyellow "Press ENTER to do it now. "
if (::KeyAvailable) {
$key = $Host.UI.RawUI.ReadKey("AllowCtrlC,IncludeKeyDown,NoEcho")
if ($key.virtualKeyCode -eq 13) { break }
if ($key.virtualKeyCode -eq 27) { write-host; exit }
}
sleep 1
}
write-host
get-process chrome | ?{
$_.MainWindowHandle.toInt64() -and ($_ | gps -file).FileName -eq $exe
} | %{
"`tTrying to exit gracefully..."
if ($_.CloseMainWindow()) {
sleep 1
}
}
$killLabelShown = 0
get-process chrome | ?{
($_ | gps -file | select -expand FileName) -eq $exe
} | %{
if (!$killLabelShown++) {
"`tTerminating background chrome processes..."
}
stop-process $_ -force
}
sleep -milliseconds 200
}
$ErrorActionPreference = $EA
$bytes = ::ReadAllBytes($dll)
$bytes[$stroffs] = 0
"`tPATCHED $flag flag"
# patch the channel restriction code for stable/beta
$rxChannel = '83-F8-(?:03-7D|02-7F|02-0F-8F)'
# old code: cmp eax,3; jge ...
# new code: cmp eax,2; jg ... (jg can be 2-byte)
function patch64 {
$pos = 0
$rx = "$rxChannel-.{1,100}-48-8D"
do {
$m = $rx.match($code,$pos)
if (!$m.success) { break }
$chanpos = $searchBase + $m.index/3 + 2
$pos = $m.index + $m.length + 1
$offs = $BC::ToUInt32($bytes, $searchBase + $pos/3+1)
$diff = $searchBase + $pos/3+5+$offs - $stroffs
} until ($diff -ge 0 -and $diff -le 4096 -and $diff % 256 -eq 0)
if (!$m.success) {
$rx = "84-C0.{18,48}($rxChannel)-.{30,60}84-C0"
$m = $rx.matches($code)
if ($m.count -ne 1) { return }
$chanpos = $searchBase + $m.groups.index/3 + 2
}
$chanpos
}
function patch86 {
$flagOffs = $stroffs + $imagebase32
$flagOffsStr = $BC::ToString($BC::GetBytes($flagOffs))
$variants = "(?<channel>$rxChannel-.{1,100})-68-(?<flag>`$1-.{6}`$2)",
"68-(?<flag>`$1-.{6}`$2).{300,500}E8.{12,32}(?<channel>$rxChannel)",
"E8.{12,32}(?<channel>$rxChannel).{300,500}68-(?<flag>`$1-.{6}`$2)"
forEach ($variant in $variants) {
$pattern = $flagOffsStr -replace '^(..)-.{6}(..)', $variant
$patternDisplay = $pattern -replace '^(.{40}).+', '$1'
write-host -f darkgray "`tLooking for $patternDisplay..."
$minDiff = 65536
foreach ($m in ::matches($code, $pattern)) {
$maybeFlagOffs = $BC::toUInt32($bytes, $searchBase +
$m.groups['flag'].index/3)
$diff = ::abs($maybeFlagOffs - $flagOffs)
if ($diff % 256 -eq 0 -and $diff -lt $minDiff) {
$minDiff = $diff
$chanpos = $searchBase + $m.groups['channel'].index/3 + 2
}
}
}
$chanpos
}
$searchBase = ($codesize/2)
foreach ($pass in 1..2) {
if ($centbrowser) { break }
$code = $BC::ToString($bytes, $searchBase, $codesize - $searchBase)
$chanpos = if ($is64) { patch64 } else { patch86 }
if ($chanpos) { break }
$codesize = $searchBase
$searchBase = 0
}
if ($chanpos) {
$bytes[$chanpos] = 9
"`tPATCHED Chrome release channel restriction"
} elseif (!$centbrowser) {
write-host -f red "`tUnable to find the channel code, try updating me"
write-host -f red "`thttp://stackoverflow.com/a/30361260"
return
}
"`tWriting to a temporary dll..."
::WriteAllBytes("$dll.new",$bytes)
"`tBacking up the original dll..."
move -literal $dll "$dll.bak" -force
"`tRenaming the temporary dll as the original dll..."
move -literal "$dll.new" $dll -force
write-host -f green "`tDONE.`n"
::Collect()
}
mainx64的特征码似乎是
FE 83 F8 03 7D ?? 83 3D -> ?? ?? ?? 09 ?? ?? ?? ??
45 78 74 65 6E 73 69 6F 6E 44 65 76 65 6C 6F 70 65 72 4D 6F 64 65 57 61 72 6E 69 6E 67 -> 00 ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ?? ??
风筝不会断弦 发表于 2017-1-8 11:05
没效果啊,
如果生成了chrome.dll.bak文件说明禁用成功,如果不起作用可以尝试将chrome.dll.bak覆盖chrome.dll并重新运行 os51 发表于 2017-1-8 11:14
如果生成了chrome.dll.bak文件说明禁用成功,如果不起作用可以尝试将chrome.dll.bak覆盖chrome.dll并重新 ...
哪里有chrome.dll.bak 唔,谢谢楼主分享 请教64位的怎么处理,本人小白 风筝不会断弦 发表于 2017-1-4 21:13
请教64位的怎么处理,本人小白
会自动识别32/64位 这个禁用后还能打开吗?
os51 发表于 2017-1-5 10:45
会自动识别32/64位
是把代码复制到记事本然后改后缀为BAT运行就可以吗 caijinqi1998 发表于 2017-1-5 12:43
这个禁用后还能打开吗?
禁用后会生成chrome.dll.bak文件,覆盖回去即可还原 风筝不会断弦 发表于 2017-1-5 13:22
是把代码复制到记事本然后改后缀为BAT运行就可以吗
并且要在chrome.dll同目录运行 os51 发表于 2017-1-5 13:53
并且要在chrome.dll同目录运行
没效果啊,
页:
[1]
2