资源共享吧|易语言论坛|逆向破解教程|辅助开发教程|网络安全教程|www.zygx8.com|我的开发技术随记

 找回密码
 注册成为正式会员
查看: 985|回复: 4

[安卓逆向] 哪位大佬帮我看一下代码,运行后获得的进程id是错误的?(安卓上运行的程序)

[复制链接]

8

主题

225

帖子

0

精华

中级会员

Rank: 3Rank: 3

资源币
3
积分
232
贡献
0
在线时间
60 小时
注册时间
2020-3-20
最后登录
2023-1-20
发表于 2020-3-24 19:40:15 | 显示全部楼层 |阅读模式
5资源币
本帖最后由 wangda38 于 2020-3-24 19:46 编辑

///根据包名查找游戏进程pid
int getPID(const char *pack_name) {
    int id = -1, pid = -1;
    DIR *dir = 0;
    FILE *file = 0;
    char filename[32] = {0};
    char cmdline[256] = {0};
    struct dirent *entry = 0;

    if (pack_name == NULL) {
        return -1;
        }

    dir = opendir("/proc");
    if (dir == NULL) {
        return -1;
        }

    while ((entry = readdir(dir)) != NULL) {
        id = atoi(entry->d_name);
        if (id > 0) {
            sprintf(filename, "/proc/%d/cmdline", id);
            file = fopen(filename, "r");

            if (file) {
                fgets(cmdline, sizeof(cmdline), file);
                fclose(file);

                if (strcmp(pack_name, cmdline) == 0) {
                    pid = id;
                    break;
                    }
                }
            }
        }
    closedir(dir);
    return pid;
}


extern "C"
jint Java_com_example_appc_aaa_searchMem(JNIEnv *env, jobject thiz) {
    char *game = "com.bb.bb"; //包名
int pid = getPID(game);
    return pid;
}







最佳答案

查看完整内容

我这边正常啊,没毛病啊
回复

使用道具 举报

2353

主题

1万

帖子

304

精华

管理员

Rank: 9Rank: 9Rank: 9

资源币
5386
积分
17489
贡献
97
在线时间
7250 小时
注册时间
2015-4-14
最后登录
2024-4-19

论坛管理员超级版主终身VIP会员资源共享吧男神终身成就

发表于 2020-3-24 19:40:16 | 显示全部楼层
wangda38 发表于 2020-3-25 12:19
你好,代码运行到
if (strcmp(process_name, cmdline) == 0) {
                                     ...

我这边正常啊,没毛病啊
回复

使用道具 举报

2353

主题

1万

帖子

304

精华

管理员

Rank: 9Rank: 9Rank: 9

资源币
5386
积分
17489
贡献
97
在线时间
7250 小时
注册时间
2015-4-14
最后登录
2024-4-19

论坛管理员超级版主终身VIP会员资源共享吧男神终身成就

发表于 2020-3-24 23:02:21 | 显示全部楼层
int find_pid_of(const char *process_name)
{
        int id;
        pid_t pid = -1;
        DIR* dir;
        FILE *fp;
        char filename[32];
        char cmdline[256];

        struct dirent * entry;

        if (process_name == NULL)
                return -1;

        dir = opendir("/proc");
        if (dir == NULL)
                return -1;

        while ((entry = readdir(dir)) != NULL) {
                id = atoi(entry->d_name);
                if (id != 0) {
                        sprintf(filename, "/proc/%d/cmdline", id);
                        fp = fopen(filename, "r");
                        if (fp) {
                                fgets(cmdline, sizeof(cmdline), fp);
                                fclose(fp);

                                if (strcmp(process_name, cmdline) == 0) {
                                        /* process found */
                                        pid = id;
                                        break;
                                }
                        }
                }
        }

        closedir(dir);
        return pid;
}

extern "C"
jint Java_com_example_appc_aaa_searchMem(JNIEnv *env, jobject thiz) {
    pid_t target_pid;
    target_pid = find_pid_of("com.bb.bb");
    return pid;
}
回复

使用道具 举报

8

主题

225

帖子

0

精华

中级会员

Rank: 3Rank: 3

资源币
3
积分
232
贡献
0
在线时间
60 小时
注册时间
2020-3-20
最后登录
2023-1-20
 楼主| 发表于 2020-3-25 12:19:23 | 显示全部楼层
admin 发表于 2020-3-24 23:02
int find_pid_of(const char *process_name)
{
        int id;

你好,代码运行到
if (strcmp(process_name, cmdline) == 0) {
                                        /* process found */
                                        pid = id;
                                        break;
                                }
这里的包名匹配不对返回得不到id,
我调试后看到的cmdline得到的包名是当前本程序在进程中的包名,
无法得到其他的包名。
大佬请问这个怎么解决
回复

使用道具 举报

8

主题

225

帖子

0

精华

中级会员

Rank: 3Rank: 3

资源币
3
积分
232
贡献
0
在线时间
60 小时
注册时间
2020-3-20
最后登录
2023-1-20
 楼主| 发表于 2020-3-26 17:33:59 | 显示全部楼层
admin 发表于 2020-3-25 17:53
我这边正常啊,没毛病啊

请问你的root权限用c是怎么实现的?我这好像是权限不对
回复

使用道具 举报

 点击右侧快捷回复  

本版积分规则

小黑屋|资源共享吧 ( 琼ICP备2021005790号-1 )

GMT+8, 2024-4-19 00:38 , Processed in 0.057028 second(s), 13 queries , MemCached On.

Powered by Discuz! X3.4 Licensed

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表