黑帽联盟

 找回密码
 会员注册
查看: 1306|回复: 0
打印 上一主题 下一主题

[脚本语言] 通过登陆IP记录Linux所有用户所操作的日志

[复制链接]
yun 黑帽联盟官方人员 

920

主题

37

听众

1364

积分

超级版主

Rank: 8Rank: 8

  • TA的每日心情
    奋斗
    2019-10-18 11:20
  • 签到天数: 678 天

    [LV.9]以坛为家II

    对于Linux用户操作记录一般通过命令history来查看历史记录,但是如果在由于误操作而删除了重要的数据的情况下,history命令就不会有什么作用了.那么依然要存有历史操作记录应该如何来实现呢?

    其实我们可以通过登陆IP地址来记录所有用户登录所操作的历史操作!具体操作就是在/etc/profile配置文件的末尾加入以下脚本代码来实现:

    cat >>/etc/profile<< EOF
    1. # History
    2. USER=`whoami`
    3. USER_IP=`who -u am i 2>/dev/null| awk '{print $NF}'|sed -e 's/[()]//g'`
    4. if [ "$USER_IP" = "" ]; then
    5. USER_IP=`hostname`
    6. fi
    7. if [ ! -d /usr/local/history ]; then
    8. mkdir /usr/local/history
    9. chmod 777 /usr/local/history
    10. fi
    11. if [ ! -d /usr/local/history/${LOGNAME} ]; then
    12. mkdir /usr/local/history/${LOGNAME}
    13. chmod 300 /usr/local/history/${LOGNAME}
    14. fi
    15. export HISTSIZE=10000
    16. DT=`date +"%Y-%m-%d_%H:%M:%S"`
    17. export HISTFILE="/usr/local/history/${LOGNAME}/${USER}@${USER_IP}_history.$DT"
    18. chmod 600 /usr/local/history/${LOGNAME}/*history* 2>/dev/null
    复制代码
    source /etc/profile使上面的代码生效.
    然后退出系统重新登录才会有记录.

    通过上面脚本可以看出,在/usr/local/下新建history目录,文件名有用户、IP、时间信息.
    ll /usr/local/history/root/

    帖子永久地址: 

    黑帽联盟 - 论坛版权1、本主题所有言论和图片纯属会员个人意见,与本论坛立场无关
    2、本站所有主题由该帖子作者发表,该帖子作者与黑帽联盟享有帖子相关版权
    3、其他单位或个人使用、转载或引用本文时必须同时征得该帖子作者和黑帽联盟的同意
    4、帖子作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
    5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
    6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
    7、黑帽联盟管理员和版主有权不事先通知发贴者而删除本文

    您需要登录后才可以回帖 登录 | 会员注册

    发布主题 !fastreply! 收藏帖子 返回列表 搜索
    回顶部