Linux popen跨进程调用

22 篇文章 0 订阅
1 篇文章 0 订阅

 

被调用代码:sum.cpp

 

#include <stdio.h>
#include <string.h>
#include <errno.h>
int main(int argc,char*argv[])
{
    int a = 2;
    int b = 3;
    printf("==sum is %d\n", a + b);
    return a + b;
}

g++ -o sum sum.cpp

 

调用代码:popen.cpp

#include <stdio.h>
#include <string.h>
#include <errno.h>
int main(int argc,char*argv[])
{
    FILE *fstream = NULL;
    char buff[1024];
    memset(buff, 0, sizeof(buff));

    if(NULL == (fstream = popen("./sum","r")))
    {
        fprintf(stderr,"execute command failed: %s",strerror(errno));
        return -1;
    }

    while(NULL != fgets(buff, sizeof(buff), fstream))
    {
            printf("popen fgets %s",buff);
    }
    pclose(fstream);

    return 0;
}

g++ -o popen popen.cpp

结果:

root@7f4dc6e8ef5e:/test# ./popen
popen fgets ==sum is 5

 

进一步,多线程+多进程

sum.cpp

#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc,char*argv[])
{
    int a = 2;
    int b = 3;
    if(argc < 1)
    {
            return -1;
    }
    int sleep_time = atoi(argv[1]);
    printf("sleep %d\n",sleep_time);
    sleep(sleep_time);
    printf("==sum is %d\n", a + b);
    return a + b;
}

 

g++ -o sum sum.cpp

 

popen.cpp

#include <stdio.h>
#include <string.h>
#include <errno.h>
#include <string>

#include <iostream>

#include <thread>
#include <pthread.h>
using namespace std;

#define NUM_THREADS 2

void* work(void* sleep_time)
{
   char *c = new char;
   sprintf(c,"%d",sleep_time);

   std::string str = std::string(c);
   str = "./sum " + str;

    FILE *fstream = NULL;
    char buff[1024];
    memset(buff, 0, sizeof(buff));

    if(NULL == (fstream = popen(str.c_str(),"r")))
    {
        fprintf(stderr,"execute command failed: %s",strerror(errno));
        return 0;
    }

    while(NULL != fgets(buff, sizeof(buff), fstream))
    {
            printf("popen fgets %s",buff);
    }
    pclose(fstream);
    return 0;

}

int main(int argc,char*argv[])
{
    int a = 6;
    pthread_t tids[NUM_THREADS];
    for(int i = 0; i < NUM_THREADS; ++i)
    {
        int b = a-i*2;
        printf("begin %d\n",b);
        int ret = pthread_create(&tids[i], NULL, work, (void*)b);
        printf("end %d\n",b);
        if (ret != 0)
        {
           cout << "pthread_create error: error_code=" << ret << endl;
        }
    }
    pthread_exit(NULL);

    return 0;
}

 

g++ -o popen popen.cpp -lpthread

运行结果:

root@7f4dc6e8ef5e:/test# ./popen
begin 6
end 6
begin 4
end 4
popen fgets sleep 4
popen fgets ==sum is 5
popen fgets sleep 6
popen fgets ==sum is 5

 

//官方网站:www.feiyuol.com //郁金香灬老师 //QQ 150330575 //个人网站:www.yjxsoft.com 进程调用CALL 进程调用带多个的参数CALL // myInject_dll.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include #include"RWA.h" //PVOID 进程分配内存(WORD nSize ); //1、获取进程句柄 //2、读写 分配内存 创建线程 //3、进程分配内存 void mycall() { PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); printf("按回车键 释放内存\n"); getchar(); 进程释放内存(p1,1000); printf("已经 释放内存\n"); } LPTHREAD_START_ROUTINE a; BOOL 进程调用CALL(PVOID pcall地址,PVOID plst参数 ); //LoadLibraryA(dll名字指针) //MessageBeep(1) void Test远程调用MessageBeep() { 进程调用CALL(MessageBeep,(PVOID)0x12768); } //注入my022MFC.dll到目标进程 void Test3() { char szDllName[]="my022MFC.dll"; //全路径 // char szDllName[]="C:\\Users\\yjxsoft\\Documents\\visual studio 2010\\Projects\\my022\\Debug\\my022MFC.dll"; PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 进程调用CALL(LoadLibraryA,(PVOID)p1); } void Test4() { // char szDllName[]="my022MFC.dll"; //全路径 char szDllName[]="E:\\1905\\代码\\my022-24\\Debug\\my022MFC.dll"; PVOID p1=进程分配内存(1000); printf("分配的内存地址=%p\n",p1); WN((DWORD)p1,szDllName,sizeof(szDllName));//WriteProcessMemory /*进程调用CALL(LoadLibraryA,(PVOID)szDllName);*/ 进程调用CALL(LoadLibraryA,(PVOID)p1); } int _tmain(int argc, _TCHAR* argv[]) { //mycall(); Test3(); Test4(); return 0; } //作业 //1、练习进程注入DLL //2、进程分配的内存内存 使用完后 用VirtualFreeEx释放掉 //3、进程句柄使用完后用CloseHandle释放句柄资源
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值