程序调用plink.exe发送命令设置路由

本文介绍如何通过编程方式调用cmd.exe执行plink.exe命令,实现远程登录路由器并执行配置命令的过程。重点阐述了初始化、发送命令及接收反馈的代码实现。

    项目要求程序调用cmd.exe然后执行plink.exe登录到路由器,然后执行路由器的命令对其进行设置。本体和cmd.exe交换数据,发送命令到cmd.exe然后从其获取执行的结果进行判断。代码如下:

初始化代码:

BOOL CMotorolaSetDlg::OpenCMDProcess()
{
    SECURITY_ATTRIBUTES sa;
    STARTUPINFO si;
    TCHAR cmdLine[256] = {0};
    TCHAR wcRcvBuff[1024] = {0};
    PROCESS_INFORMATION ProcessInformation;

    sa.nLength=sizeof(sa);
    sa.lpSecurityDescriptor=0;
    sa.bInheritHandle=true;

    if(!CreatePipe(&(this->m_hReadPipe1),&(this->m_hWritePipe1),&sa,0))
    {
        return FALSE;
    }
    if(!CreatePipe(&(this->m_hReadPipe2),&(this->m_hWritePipe2),&sa,0))
    {
        return FALSE;
    }

    ZeroMemory(&si,sizeof(si));
    GetStartupInfo(&si);
    si.dwFlags = STARTF_USESHOWWINDOW|STARTF_USESTDHANDLES;
    si.wShowWindow = SW_HIDE;
    si.hStdInput = this->m_hReadPipe2;
    si.hStdOutput = si.hStdError = this->m_hWritePipe1;

    GetSystemDirectory(cmdLine,sizeof(cmdLine));
    _tcscat(cmdLine, _T("\\cmd.exe"));
    if(CreateProcess(cmdLine,NULL,NULL,NULL,TRUE,0,NULL,NULL,&si,&ProcessInformation) == 0)
    {
        return FALSE;
    }

    return TRUE;

}

发送命令到cmd.exe的代码:

BOOL CMotorolaSetDlg::SndCmdToPipe(CString csCmd)
{
    BOOL bRet = FALSE;
    unsigned long ulBytesRead = 0;
    char* pcCmd = NULL;

    pcCmd = CStringToChar(csCmd);

    bRet = WriteFile(this->m_hWritePipe2, pcCmd,csCmd.GetLength()+1,&ulBytesRead,0);

    if(pcCmd != NULL)
    {
        delete pcCmd;
    }

    return bRet;
}

从cmd.exe接收反馈的代码:

BOOL CMotorolaSetDlg::RcvDataFromPipe(TCHAR* pwcBuff, DWORD dwLen)
{
    BOOL bRet = FALSE;
    unsigned long ulBytesRead = 0;
    
    if(dwLen > sizeof(pwcBuff) && pwcBuff == NULL)
    {
        bRet = FALSE;
    }
    else
    {
        memset(pwcBuff, 0, dwLen);
        bRet = PeekNamedPipe(this->m_hReadPipe1,pwcBuff,dwLen,&ulBytesRead,0,0);
        if(bRet)    
        {
            bRet = ReadFile(this->m_hReadPipe1,pwcBuff,dwLen,&ulBytesRead,0);
        }
        else
        {
            bRet = FALSE;
        }
    }


    return bRet;
}


static int add_ifprefix(optinfo, dhcpifp, ia, siteprefix, prefix, pconf) struct dhcp6_optinfo *optinfo; struct dhcp6_if *dhcpifp; struct ia *ia; struct siteprefix *siteprefix; struct dhcp6_prefix *prefix; struct prefix_ifconf *pconf; { struct dhcp6_ifprefix *ifpfx = NULL; struct in6_addr *a; u_long sla_id; char *sp; int b, i; if ((ifpfx = malloc(sizeof(*ifpfx))) == NULL) { debug_printf(LOG_NOTICE, FNAME, "failed to allocate memory for ifprefix"); return (-1); } memset(ifpfx, 0, sizeof(*ifpfx)); ifpfx->ifconf = pconf; ifpfx->paddr.sin6_family = AF_INET6; #ifdef HAVE_SA_LEN ifpfx->paddr.sin6_len = sizeof(struct sockaddr_in6); #endif ifpfx->paddr.sin6_addr = prefix->addr; ifpfx->plen = prefix->plen + pconf->sla_len; /* * XXX: our current implementation assumes ifid len is a multiple of 8 */ if ((pconf->ifid_len % 8) != 0) { debug_printf(LOG_ERR, FNAME, "assumption failure on the length of interface ID"); goto bad; } if (ifpfx->plen + pconf->ifid_len < 0 || ifpfx->plen + pconf->ifid_len > 128) { debug_printf(LOG_INFO, FNAME, "invalid prefix length %d + %d + %d", prefix->plen, pconf->sla_len, pconf->ifid_len); goto bad; } /* copy prefix and SLA ID */ a = &ifpfx->paddr.sin6_addr; b = prefix->plen; for (i = 0, b = prefix->plen; b > 0; b -= 8, i++) a->s6_addr[i] = prefix->addr.s6_addr[i]; sla_id = htonl(pconf->sla_id); sp = ((char *)&sla_id + 3); i = (128 - pconf->ifid_len) / 8; for (b = pconf->sla_len; b > 7; b -= 8, sp--) a->s6_addr[--i] = *sp; if (b) a->s6_addr[--i] |= *sp; /* configure the corresponding address */ ifpfx->ifaddr = ifpfx->paddr; for (i = 15; i >= pconf->ifid_len / 8; i--) ifpfx->ifaddr.sin6_addr.s6_addr[i] = pconf->ifid[i]; #if 0 if (pd_ifaddrconf(IFADDRCONF_ADD, ifpfx)) goto bad; #endif /* TODO: send a control message for other processes */ TAILQ_INSERT_TAIL(&siteprefix->ifprefix_list, ifpfx, plink); return (0); bad: if (ifpfx) free(ifpfx); return (-1); } 接口的作用
最新发布
12-09
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值