百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

微小的CMD 微小的力量

yuyutoo 2024-10-21 11:59 9 浏览 0 评论

本文的目的是说明如何从任何应用程序(无论其类型(MFC,Win32,控制台))运行CMD命令,等待结果并使用您自己的用户界面查看它们。

背景

作为SecuredGlobe,Inc.日常工作的一部分,我们运行预制程序。他们所做的只是在响应结果的同时以编程方式执行一系列CMD命令。这就提出了为此目的构建通用工具的想法。

“如何”

首先,我们定义3个全局变量来存储命令的异步处理状态。

Command-您将在CMD中键入的命令

CommandResult-执行完成后您将在屏幕上看到的结果

IsRunning-指示命令是否仍在处理中。要测试处理时间更长的命令,请尝试输入“netstat”

CString Command, CommandResult;
BOOL IsRunning = FALSE;12复制代码类型:[cpp]

DoRun()函数

我们编写string发送给ShellExecute()的实际位置是DoRun()。

提提您:您可能更喜欢使用ShellExecuteEx()或CreateProcess()。

该DoRun()函数首先删除result.txt的任何旧版本,然后正确发送命令。

BOOL DoRun(WCHAR *command)
{
    BOOL Result = FALSE;
    DWORD retSize;
    LPTSTR pTemp = NULL;
    TCHAR Command[BUFSIZE] = L"";
    if (!(DeleteFile(RESULTS_FILE)))
    {
        //return L"Can't delete previous results";
    }
    _tcscpy_s(Command, L"/C ");
    _tcscat_s(Command, command);
    _tcscat_s(Command, L" >");
    _tcscat_s(Command, RESULTS_FILE);
    wprintf(L"Calling:\n%s\n", Command);
    Result = (BOOL) ShellExecute(GetActiveWindow(), L"OPEN", L"cmd", Command, NULL, 0L);
    if(!Result)
    {
        retSize = FormatMessage(FORMAT_MESSAGE_ALLOCATE_BUFFER |
            FORMAT_MESSAGE_FROM_SYSTEM |
            FORMAT_MESSAGE_ARGUMENT_ARRAY,
            NULL,
            GetLastError(),
            LANG_NEUTRAL,
            (LPTSTR)&pTemp,
            0,
            NULL);
        MessageBox(NULL,pTemp,L"Error",MB_OK);
    }
    return Result;
}12345678910111213141516171819202122232425262728293031复制代码类型:[cpp]

SetCommand函数

该SetCommand函数用于通过其自己的线程启动新命令。

void SetCommand(CString command)
{
    Command = command;
    HANDLE hThread = (HANDLE)_beginthread(ThreadFunc, 0, NULL);
}12345复制代码类型:[cpp]

然后线程函数本身如下:

void __cdecl ThreadFunc(void*) 
{
    CommandResult = L"";
    if (DoRun(Command.GetBuffer()))
    {
        IsRunning = TRUE;

        while (IsRunning)
        {
            if(CheckCommandExecutionStatus())
            {
                break;
            }
        }
    }
    IsRunning = FALSE;
    _endthreadex(0);
}123456789101112131415161718复制代码类型:[cpp]

CheckCommandResult()像这样:

bool CheckCommandExecutionStatus()
{
    CommandResult = GetResultFromFile();
    if (CommandResult != L"")
        return true;
    else
        return false;
}12345678复制代码类型:[cpp]

得到结果

命令执行完成后,我们希望将结果保存在.txt文件中,然后重新使用。文件名为“result.txt”。

该GetResultFromFile()函数读取该文件并返回CString结果。

带注释的部分可用于无法打开文件的情况,但是由于不希望发生这种情况,因此我已注释了该部分。

CString GetResultFromFile()
{
    CString strResult = L"";
    std::FILE *fp;
    fp = NULL;
    _wfopen_s(&fp, RESULTS_FILE, L"rb");
    if (fp)
    {
        std::string contents;
        std::fseek(fp, 0, SEEK_END);
        contents.resize(std::ftell(fp));
        std::rewind(fp);
        std::fread(&contents[0], 1, contents.size(), fp);
        std::fclose(fp);
        CString temp1 = (CString)(CStringA)(contents.c_str());
        wprintf(L"Result:\n%s\n", temp1.GetBuffer());
        if (temp1 == L"") temp1 = L"Unknown command";
        strResult = temp1;
    }
    /*else
    {
        DWORD lastError = GetLastError();
        if (lastError == 32)
        {
            // File is locked since it is being prepared
            return strResult;
        }
        strResult.Format(L"Can't open file %s. Error %d", RESULTS_FILE, lastError);
        return strResult;
    }*/
    return strResult;
}1234567891011121314151617181920212223242526272829303132复制代码类型:[cpp]

进一步增强

由于应给予笔者EASY-SIZE,马克Richarme。每次调整对话框大小时,都可以轻松使用EASY-SIZE来支持调整对话框中控件的大小。

结果,该对话框最初看起来可能是这样的:

然后调整大小,如下所示:

字体支持

我希望文字清晰且足够大。我选择了140点快递。

首先,我们定义m_font为成员变量:

CFont m_Font;1复制代码类型:[cpp]

然后,作为的一部分OnInitDialog,我们调用:

m_Font.CreatePointFont(140, _T("Courier"));1复制代码类型:[cpp]

然后,要将字体分配给特定控件(在我们的示例中为Command和Command结果,我们使用以下代码:

CommandTyped.SetFont(&m_Font);1复制代码类型:[cpp]

文字颜色

要在黑色文本上设置黄色,我们使用SetTextColor()和SetBkColor()。我们将以下调用添加到OnCtrColor():

case CTLCOLOR_EDIT:
    if(ID == IDC_CMD_RESULT || ID == IDC_COMMAND)
    {
        pDC->SetTextColor(COLOR_YELLOW);
        pDC->SetBkColor(COLOR_BLACK);
        return (HBRUSH)(m_brush->GetSafeHandle());
    }
    break;12345678复制代码类型:[cpp]

始终最好分别定义常量,并且在大多数情况下,无需再次输入它们的值即可再次使用它们。在这种情况下,我定义了字体名称以及头文件中的黄色和黑色。

#define FONT_NAME        _T("Courier")
#define COLOR_BLACK        RGB(0, 0, 0)
#define COLOR_YELLOW    RGB(204, 204, 0)

相关推荐

当 Linux 根分区 (/) 已满时如何释放空间?

根分区(/)是Linux文件系统的核心,包含操作系统核心文件、配置文件、日志文件、缓存和用户数据等。当根分区满载时,系统可能出现无法写入新文件、应用程序崩溃甚至无法启动的情况。常见原因包括:...

玩转 Linux 之:磁盘分区、挂载知多少?

今天来聊聊linux下磁盘分区、挂载的问题,篇幅所限,不会聊的太底层,纯当科普!!1、Linux分区简介1.1主分区vs扩展分区硬盘分区表中最多能存储四个分区,但我们实际使用时一般只分为两...

Linux 文件搜索神器 find 实战详解,建议收藏

在Linux系统使用中,作为一个管理员,我希望能查找系统中所有的大小超过200M文件,查看近7天系统中哪些文件被修改过,找出所有子目录中的可执行文件,这些任务需求...

Linux 操作系统磁盘操作(linux 磁盘命令)

一、文档介绍本文档描述Linux操作系统下多种场景下的磁盘操作情况。二、名词解释...

Win10新版19603推送:一键清理磁盘空间、首次集成Linux文件管理器

继上周四的Build19592后,微软今晨面向快速通道的Insider会员推送Windows10新预览版,操作系统版本号Build19603。除了一些常规修复,本次更新还带了不少新功能,一起来了...

Android 16允许Linux终端使用手机全部存储空间

IT之家4月20日消息,谷歌Pixel手机正朝着成为强大便携式计算设备的目标迈进。2025年3月的更新中,Linux终端应用的推出为这一转变奠定了重要基础。该应用允许兼容的安卓设备...

Linux 系统管理大容量磁盘(2TB+)操作指南

对于容量超过2TB的磁盘,传统MBR分区表的32位寻址机制存在限制(最大支持2.2TB)。需采用GPT(GUIDPartitionTable)分区方案,其支持64位寻址,理论上限为9.4ZB(9....

Linux 服务器上查看磁盘类型的方法

方法1:使用lsblk命令lsblk输出说明:TYPE列显示设备类型,如disk(物理磁盘)、part(分区)、rom(只读存储)等。...

ESXI7虚机上的Ubuntu Linux 22.04 LVM空间扩容操作记录

本人在实际的使用中经常遇到Vmware上安装的Linux虚机的LVM扩容情况,最终实现lv的扩容,大多数情况因为虚机都是有备用或者可停机的情况,一般情况下通过添加一块物理盘再加入vg,然后扩容lv来实...

5.4K Star很容易!Windows读取Linux磁盘格式工具

[开源日记],分享10k+Star的优质开源项目...

Linux 文件系统监控:用脚本自动化磁盘空间管理

在Linux系统中,文件系统监控是一项非常重要的任务,它可以帮助我们及时发现磁盘空间不足的问题,避免因磁盘满而导致的系统服务不可用。通过编写脚本自动化磁盘空间管理,我们可以更加高效地处理这一问题。下面...

Linux磁盘管理LVM实战(linux实验磁盘管理)

LVM(逻辑卷管理器,LogicalVolumeManager)是一种在Linux系统中用于灵活管理磁盘空间的技术,通过将物理磁盘抽象为逻辑卷,实现动态调整存储容量、跨磁盘扩展等功能。本章节...

Linux查看文件大小:`ls`和`du`为何结果不同?一文讲透原理!

Linux查看文件大小:ls和du为何结果不同?一文讲透原理!在Linux运维中,查看文件大小是日常高频操作。但你是否遇到过以下困惑?...

使用 df 命令检查服务器磁盘满了,但用 du 命令发现实际小于磁盘容量

在Linux系统中,管理员或开发者经常会遇到一个令人困惑的问题:使用...

Linux磁盘爆满紧急救援指南:5步清理释放50GB+小白也能轻松搞定

“服务器卡死?网站崩溃?当Linux系统弹出‘Nospaceleft’的红色警报,别慌!本文手把手教你从‘删库到跑路’进阶为‘磁盘清理大师’,5个关键步骤+30条救命命令,快速释放磁盘空间,拯救你...

取消回复欢迎 发表评论: