bash에서 임시 파일 만들기
bash 스크립트에서 임시 파일을 작성하는 객관적으로 더 나은 방법이 있습니까?
나는 보통 스크립트가 끝날 때 삭제되므로 tempfile-123과 같이 내 마음에 오는 모든 것을 이름을 지정합니다. 현재 폴더에서 가능한 tempfile-123을 덮어 쓰는 것 외에 다른 방법으로 단점이 있습니까? 아니면 더 신중하게 임시 파일을 만들면 어떤 이점이 있습니까?
mktemp(1)
man 페이지는 상당히 잘 설명 :
전통적으로 많은 쉘 스크립트는 pid를 접미사로하여 프로그램 이름을 임시 파일 이름으로 사용합니다. 이러한 종류의 명명 체계는 예측 가능하며 생성 된 경쟁 조건은 공격자가 이기기 쉽습니다. 여전히 안전하지는 않지만보다 안전한 방법은 동일한 이름 지정 체계를 사용하여 임시 디렉토리를 만드는 것입니다. 이렇게하면 임시 파일이 전복되지 않도록 보장 할 수 있지만 여전히 간단한 서비스 거부 공격이 허용됩니다. 이러한 이유로 mktemp를 대신 사용하는 것이 좋습니다.
스크립트에서 다음과 같은 mktemp를 호출합니다.
mydir=$(mktemp -d "${TMPDIR:-/tmp/}$(basename $0).XXXXXXXXXXXX")
작업 할 수있는 임시 디렉토리를 만들고 실제 파일을 읽기 쉽고 유용한 이름으로 안전하게 지정할 수 있습니다.
mktemp
표준은 아니지만 많은 플랫폼에 존재합니다. "X"는 일반적으로 임의의 임의성으로 변환되며, 더 많은 것은 아마도 임의성 일 것입니다. 그러나 일부 시스템 (busybox ash)은이 임의성을 다른 시스템보다 더 크게 제한합니다.
그런데 임시 파일의 안전한 생성은 단순한 쉘 스크립팅 이상으로 중요합니다. 그렇기 때문에 파이썬에는 tempfile이 있고 perl에는 File :: Temp , ruby에는 Tempfile 등이 있습니다.
예, mktemp를 사용하십시오 .
임시 파일을 저장하도록 설계된 폴더 안에 임시 파일을 생성하며 고유 한 이름을 보장합니다. 해당 파일의 이름을 출력합니다.
> mktemp
/tmp/tmp.xx4mM3ePQY
>
보고 싶을 수도 있습니다 mktemp
mktemp 유틸리티는 주어진 파일 이름 템플릿을 가져와 고유 한 파일 이름을 생성하기 위해 그 일부를 덮어 씁니다. 템플릿은 /tmp/tfile.XXXXXXXXXX와 같이 몇 개의 'X'가 추가 된 파일 이름 일 수 있습니다. 후행 'X'는 현재 프로세스 번호와 임의 문자의 조합으로 대체됩니다.
자세한 내용은 man mktemp
보다 신중한 방법으로 임시 파일을 만들면 어떤 이점이 있습니까?
임시 파일은 일반적으로 /tmp
다른 모든 사용자 및 프로세스가 읽기 및 쓰기 액세스 권한을 가진 임시 디렉토리 (예 :와 같은 )에 작성됩니다 (다른 스크립트가 새 파일을 작성할 수 있음). 따라서 스크립트는 올바른 권한으로 사용하는 등의 파일 작성에주의해야합니다 (예 : 소유자 만 읽기 : 참조). help umask
filename은 쉽게 추측 할 수 없습니다 (이상적으로 무작위). 그렇지 않으면 파일 이름이 고유하지 않으면 동일한 스크립트와 여러 번 실행 된 충돌이 발생할 수 있습니다 (예 : 경쟁 조건)) 또는 일부 공격자는 민감한 정보 (예 : 권한이 너무 열려 있고 파일 이름을 추측하기 쉬운 경우)를 납치하거나 자신의 코드 버전으로 파일을 작성 / 대체 할 수 있습니다 (예 : 명령 또는 SQL 쿼리를 현재 상태에 따라 대체) 저장 됨).
다음 방법을 사용하여 임시 디렉토리를 작성할 수 있습니다.
TMPDIR=".${0##*/}-$$" && mkdir -v "$TMPDIR"
또는 임시 파일 :
TMPFILE=".${0##*/}-$$" && touch "$TMPFILE"
그러나 여전히 예측 가능하며 안전하지 않은 것으로 간주됩니다.
에 따라 man mktemp
읽을 수 있습니다 :
전통적으로 많은 쉘 스크립트는 pid를 접미사로하여 프로그램 이름을 임시 파일 이름으로 사용합니다. 이러한 종류의 명명 체계는 예측 가능하며 생성 된 경쟁 조건은 공격자가 이기기 쉽습니다.
따라서 안전을 위해 mktemp
명령을 사용하여 고유 한 임시 파일 또는 디렉토리 ( -d
) 를 작성 하는 것이 좋습니다 .
참고 URL : https://stackoverflow.com/questions/10982911/creating-temporary-files-in-bash
'IT박스' 카테고리의 다른 글
객체가 인터페이스를 구현하는지 테스트 (0) | 2020.06.21 |
---|---|
Access-Control-Allow-Credentials 헤더는 정확히 무엇을합니까? (0) | 2020.06.21 |
IntelliJ에서 파일을 생성 할 때“작성자”스탬프 끄기 (0) | 2020.06.21 |
Hamcrest에서 목록이 비어 있지 않은지 확인 (0) | 2020.06.21 |
부스트 상태 차트와 메타 상태 머신 (0) | 2020.06.21 |