Hacking/infra 진단

[Linux] U-08 (상) /etc/shadow 파일 소유자 및 권한 설정

알거음슴 2021. 8. 17. 19:51
취약점 개요
점검 내용 /etc/shadow 파일 권한 적절성 점검
점검 목적 /etc/shadow 파일을 관리자만 제어할 수 있게 하여 비인가자들의 접근을 차단하도록 shadow 파일 소유자 및 권한을 관리해야 함
보안 위협 shadow파일은 패스워드를 암호화하여 저장하는 파일이며 해당 파일의 암호화된 해쉬값을 복호화하여(크래킹) 비밀번호를 탈취할 수 있음
참고 /etc/shadow : 시스템에 등록된 모든 계정의 패스워드를 암호화된 형태로 저장 및 관리하고 있는 파일
점검대상 및 판단 기준
대상 LINUX
판단기준 양호 : /etc/shadow 파일의 소유자가 root이고, 권한이 400 이하인 경우
취약 : /etc/shadow 파일의 소유자가 root가 아니거나, 권한이 400 이하가 아닌 경우
조치 방법 /etc/shadow” 파일의 소유자 및 권한 변경 (소유자 root, 권한 400)

 

점검 및 조치
점검 #ls -l /etc/shadow
r-------- root <shadow 파일>
위에 제시된 파일 및 디렉터리의 소유자가 root가 아니거나 파일의 권한이 400이 아닌 경우 아래의 보안설정방법에 따라 설정을 변경함
조치 Step 1) “/etc/shadow” 파일의 소유자 및 권한 확인
 #ls -l /etc/shadow
Step 2) “/etc/shadow” 파일의 소유자 및 권한 변경 (소유자 root, 권한 400)
 #chown root /etc/shadow
 #chmod 400 /etc/shad

 

점검 스크립트

#!/bin/bash

. function.sh

BAR
CODE [U-08] "/etc/shadow" 파일 소유자 및 권한 설정
cat << EOF >> $RESULT
[양호]: /etc/shadow 파일의 소유자가 root이고, 권한이 400 이하인 경우
[취약]: /etc/shadow 파일의 소유자가 root가 아니거나, 권한이 400 이하가 아닌 경우
EOF
BAR

FILE=/etc/shadow
USER=root
PERM=400

FILEUSER=$(ls -al $FILE | awk '{print $3}')
FILEPERM=$(stat -c '%a' /etc/shadow)

if [ $FILEUSER != $USER ] ; then
    VULN "/etc/shadow 파일의 소유자가 root가 아닙니다. "
else
    if [ $FILEPERM != $PERM ] ; then
        VULN "권한이 400이 아닙니다. 보안 설정 방법에 따라 권한을 변경하세요."
    else
        OK "/etc/shadow 파일의 소유자가 root이고, 권한이 400 이하인 경우"
    fi
fi

cat $RESULT