AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / computer / Perguntas / 1700602
Accepted
seagull
seagull
Asked: 2022-01-22 08:37:05 +0800 CST2022-01-22 08:37:05 +0800 CST 2022-01-22 08:37:05 +0800 CST

Usando o PowerShell para adicionar uma entrada a "PendingFileRenameOperations" sem interromper as entradas anteriores

  • 772

No meu caso, eu queria usar o valor do Registro em SYSTEM\CurrentControlSet\Control\Session Manager!PendingFileRenameOperationspara excluir um arquivo na reinicialização. Estou usando o PowerShell.
Seria relativamente fácil usar algo como MoveFileou qualquer outro binário de linha de comando para adicionar os dados ao Registro, mas considero uma má forma usar ferramentas de terceiros (mesmo Sysinternals) quando métodos nativos estão disponíveis.

O Problema
PendingFileRenameOperations só faz alguma coisa quando as entradas dentro dele (é um objeto Multistring) são sufixadas com dois caracteres NUL, mostrados no visualizador binário do Regedit como .. ... Adicionar as informações normalmente por meio do PowerShell não funciona e adicionar dados binários, embora possível, limparia todos os dados existentes no valor devido à falta de capacidade do PowerShell (certamente do PowerShell 2.0) de extrair os dados binários de um objeto Registry MultiString.

A pergunta
É possível usar métodos nativos em uma máquina PS2.0 para adicionar entradas de PendingFileRenameOperationsforma que o sistema operacional realmente as reconheça?

windows powershell
  • 2 2 respostas
  • 425 Views

2 respostas

  • Voted
  1. Best Answer
    seagull
    2022-01-22T08:37:05+08:002022-01-22T08:37:05+08:00

    Sim. Use o seguinte código do PowerShell:

    new-ItemProperty -path "HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager" -Name "PendingFileRenameOperations" -Value $($((Get-ItemProperty "HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager" -Name PendingFileRenameOperations -ErrorAction SilentlyContinue).PendingFileRenameOperations) + "\??\C:\file.exe`0`0") -type MultiString -Force | Out-Null
    

    O que estamos fazendo aqui:

    • Fazendo um novo item do tipo MultiString (usar set-itempropertynão funciona por qualquer motivo)
    • Definir, como seu valor principal, os dados que estavam nesse valor do Registro para começar (se houver)
    • Adicionando o normal \??\C:\File.exe, que neste caso é \??\+ o caminho do arquivo a ser excluído
    • Adicionando dois bytes NUL ( `0`0no PowerShell) ao final da string

    Isso garantirá que o arquivo seja excluído na próxima reinicialização.

    • 0
  2. HelpingHand
    2022-01-22T08:57:03+08:002022-01-22T08:57:03+08:00

    Você pode usar o .NET do Powershell, por exemplo:

    Add-Type @"
    using System;
    using System.Text;
    using System.Runtime.InteropServices;
    
    public class PFRO
    {
        public enum MoveFileFlags
        {
            MOVEFILE_REPLACE_EXISTING           = 0x00000001,
            MOVEFILE_COPY_ALLOWED               = 0x00000002,
            MOVEFILE_DELAY_UNTIL_REBOOT         = 0x00000004,
            MOVEFILE_WRITE_THROUGH              = 0x00000008,
            MOVEFILE_CREATE_HARDLINK            = 0x00000010,
            MOVEFILE_FAIL_IF_NOT_TRACKABLE      = 0x00000020
        }
        [DllImport("kernel32.dll", SetLastError = true, CharSet = CharSet.Unicode)]
        static extern bool MoveFileEx(string lpExistingFileName, string lpNewFileName, MoveFileFlags dwFlags);
    
        public static bool MarkFileForDelete (string srcfile)
        {
            bool brc = false;
            brc = MoveFileEx(srcfile, null, MoveFileFlags.MOVEFILE_DELAY_UNTIL_REBOOT);
            return brc;
        }
    }
    "@
    
    $FullName = "C:\toolsde.txt"
    
    if([PFRO]::MarkFileForDelete($FullName))
    {
        write-host $FullName "will be deleted on next boot"
    }
    else
    {
        write-host $FullName "will not be deleted on next boot"
    }
    

    Além disso, acredito que PendingFileRenameOperations2 também é um valor de registro processado pelo Windows Session Manager na inicialização. Suspeito que você possa usar isso para seus propósitos sem a necessidade de tocar em PendingFileRenameOperations. Pode valer a pena um teste.

    • 0

relate perguntas

  • Qual seria o equivalente em lote do argumento "pass" do Python?

  • Não é possível ativar o Microsoft Print to PDF depois de desativado

  • Posso fazer com que este script do PowerShell aceite vírgulas?

  • Comunique-se com o daemon do Docker no Windows

  • atalho do shell da área de trabalho no painel lateral do explorer

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como posso reduzir o consumo do processo `vmmem`?

    • 11 respostas
  • Marko Smith

    Baixar vídeo do Microsoft Stream

    • 4 respostas
  • Marko Smith

    O Google Chrome DevTools falhou ao analisar o SourceMap: chrome-extension

    • 6 respostas
  • Marko Smith

    O visualizador de fotos do Windows não pode ser executado porque não há memória suficiente?

    • 5 respostas
  • Marko Smith

    Como faço para ativar o WindowsXP agora que o suporte acabou?

    • 6 respostas
  • Marko Smith

    Área de trabalho remota congelando intermitentemente

    • 7 respostas
  • Marko Smith

    O que significa ter uma máscara de sub-rede /32?

    • 6 respostas
  • Marko Smith

    Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows?

    • 1 respostas
  • Marko Smith

    O VirtualBox falha ao iniciar com VERR_NEM_VM_CREATE_FAILED

    • 8 respostas
  • Marko Smith

    Os aplicativos não aparecem nas configurações de privacidade da câmera e do microfone no MacBook

    • 5 respostas
  • Martin Hope
    Saaru Lindestøkke Por que os arquivos tar.xz são 15x menores ao usar a biblioteca tar do Python em comparação com o tar do macOS? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh Como posso reduzir o consumo do processo `vmmem`? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Pesquisa do Windows 10 não está carregando, mostrando janela em branco 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 Por que uma conexão de Internet gigabit/s via cabo (coaxial) não oferece velocidades simétricas como fibra? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 Área de trabalho remota congelando intermitentemente 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney Por que colocar um ponto após o URL remove as informações de login? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension Ponteiro do mouse movendo-se nas teclas de seta pressionadas no Windows? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca Todos os meus complementos do Firefox foram desativados repentinamente, como posso reativá-los? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK É possível criar um código QR usando texto? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 Altere o nome da ramificação padrão do git init 2019-04-01 06:16:56 +0800 CST

Hot tag

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve