匿名管道实现重定向输入输出,执行adb命令()?

sanshao27 2012-09-05 05:37:58
我想通过调用adb。exe 这个控制台程序多次执行shell 命令,但是执行完第二条命令,再次通过writefile输入的时候就无法执行,通过readFile 读出的数据是第三次写入的数据。

源码。。。
char szconmand[MAX_PATH]={0};
HANDLE stdOutPipeRd,stdOutPipeWt,stdInPipeWt,stdInPipeRd;
STARTUPINFOA startUp;
SECURITY_ATTRIBUTES lpSecurity, lpSec2;
PROCESS_INFORMATION processInfo;


lpSecurity.nLength=sizeof(SECURITY_ATTRIBUTES);
lpSecurity.lpSecurityDescriptor=NULL;
lpSecurity.bInheritHandle=true;
if (!CreatePipe(&stdOutPipeRd,&stdOutPipeWt,&lpSecurity,0))
{
DWORD err=GetLastError();

return -1;
}
lpSec2.nLength=sizeof(SECURITY_ATTRIBUTES);
lpSec2.bInheritHandle=true;
lpSec2.lpSecurityDescriptor=NULL;
if (!CreatePipe(&stdInPipeRd,&stdInPipeWt,&lpSec2,0))
{
DWORD err=GetLastError();
return -1;
}

memset(&startUp,0,sizeof(STARTUPINFOA));
GetStartupInfoA(&startUp);
startUp.cb=sizeof(STARTUPINFOA);
startUp.dwFlags=STARTF_USESTDHANDLES|STARTF_USESHOWWINDOW;
startUp.wShowWindow=HIDE_WINDOW;
startUp.hStdInput=stdOutPipeRd;
startUp.hStdOutput=stdInPipeWt;
startUp.hStdError=stdInPipeWt;
char str[MAX_PATH]={0};
strcpy(str,"adb.exe shell");
char *pdata=NULL;
pdata=(char*)malloc(strlen(str)+strlen(szconmand));
if (pdata==NULL)
{
return -1;
}
memset(pdata,0,strlen(str)+strlen(szconmand));
int n=0;
n=strlen(str);
int k=strlen(szconmand);
memcpy(pdata,str,sizeof(str));
memcpy(pdata+n," ",sizeof(char));
memcpy(pdata+n+1,szconmand,k);
if (!CreateProcessA(NULL,str,NULL,NULL,TRUE,0,NULL,NULL,&startUp,&processInfo))
{
DWORD err=GetLastError();

return -1;
}
DWORD stdlen=0;
char szbuffer[MAX_PATH]={0};
while (true)
{
if(!PeekNamedPipe(stdInPipeRd,szbuffer,MAX_PATH,&stdlen,NULL,0))
{

DWORD err=GetLastError();
return -1;
}

if (stdlen)
{
break;
}
}

if (!ReadFile(stdInPipeRd,szbuffer,MAX_PATH,&stdlen,NULL))
{
DWORD err=GetLastError();
return -1;

}
memset(szbuffer,0,MAX_PATH);
char sqlCommand[MAX_PATH]={0};
strcpy(sqlCommand,"sqlite3 /data/data/com.android.providers.telephony/databases/mmssms.db\r\n");//程序执行到这还是正常的
if (!WriteFile(stdOutPipeWt,sqlCommand,strlen(sqlCommand)+1,&stdlen,0))
{
DWORD erro=GetLastError();
return -1;
}
memset(szbuffer,0,MAX_PATH);
while (true)
{
if(!PeekNamedPipe(stdInPipeRd,szbuffer,MAX_PATH,&stdlen,NULL,0))
{

DWORD err=GetLastError();
return -1;
}

if (stdlen)
{
break;
}
}

if (!ReadFile(stdInPipeRd,szbuffer,MAX_PATH,&stdlen,NULL))//独处正常执行结果
{
DWORD err=GetLastError();
return -1;

}
//memset(szbuffer,0,MAX_PATH);
memset(sqlCommand,0,MAX_PATH);
strcat(szbuffer,"select * from sms;\r\n");
if (!WriteFile(stdOutPipeWt,sqlCommand,strlen(sqlCommand),&stdlen,0))//这次写入的命令,在读的时候是原封不动的被读出来了,没有执行。只能执行两次命令,,,为什么?
{
DWORD erro=GetLastError();
return -1;
}

Sleep(5000);
while (true)
{
memset(szbuffer,0,MAX_PATH);
if(!PeekNamedPipe(stdInPipeRd,szbuffer,MAX_PATH,&stdlen,NULL,0))
{

DWORD err=GetLastError();
return -1;
}

if (stdlen)
{
break;
}
}

if (!ReadFile(stdInPipeRd,szbuffer,1024,&stdlen,NULL))
{
DWORD err=GetLastError();
return -1;

}

希望知道的朋友能不吝赐教,分数不是问题。
...全文
592 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
guest8188 2015-05-09
  • 打赏
  • 举报
回复
最后设置szbuffer 这里
awsa 2012-11-29
  • 打赏
  • 举报
回复
if (stdlen) { break; } 这块不对吧,应该是 if (!stdlen) { break; }
sanshao27 2012-09-06
  • 打赏
  • 举报
回复
谢谢上面的回答,上面的问题只是一个例子而已,我需要下面的操作,
通过管道执行以下的操作,
第一步,先执行adb shell,
等待返回后,在执行su,
检测返回的结果(这一步返回的结果是SU,感觉上面的SU就没有执行。)

希望知道的朋友,能进来解答。
Gloveing 2012-09-06
  • 打赏
  • 举报
回复
strcat(szbuffer,"select * from sms;\r\n");
if (!WriteFile(stdOutPipeWt,sqlCommand,strlen(sqlCommand),&stdlen,0))//这次写入的命令,在读的时候是原封不动的被读出来了,没有执行。只能执行两次命令,,,为什么?
------------------
你直接调用abc.exe的时候,能成功么?
还有,你断点调试一下,看看每次即将writeFile写入的参数对不对
oyljerry 2012-09-06
  • 打赏
  • 举报
回复
多加一些Log信息等,看看具体代码运行到什么地方出错了
sanshao27 2012-09-05
  • 打赏
  • 举报
回复
没人知道吗,不要沉了

15,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 进程/线程/DLL
社区管理员
  • 进程/线程/DLL社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧