


So verwenden Sie fdopen, um Berechtigungen für vom Python-Prozess generierte Dateien zu minimieren
Anforderungshintergrund
Bei der Verwendung von Python zum Erstellen, Lesen und Schreiben von Dateien achten wir selten auf die Berechtigungskonfiguration der erstellten Dateien. Wenn bei einigen Systemen mit hoher Sicherheit die von uns erstellten Dateiberechtigungen über Leseberechtigungen für andere Benutzer oder andere Benutzer derselben Benutzergruppe verfügen, besteht möglicherweise das Risiko eines unnötigen Informationsverlusts. Daher können wir nicht nur eine sicherere und privatere persönliche Umgebung (z. B. eine Containerumgebung usw.) schaffen, sondern auch die Berechtigungen für die Konfiguration der generierten Dateien minimieren.
Gemeinsame Methoden und ihre Fehleranalyse
Die häufig verwendete Methode zum Erstellen, Lesen und Schreiben von Python-Dateien besteht darin, eine Datei direkt über die integrierte Öffnungsfunktion zu erstellen. Wenn es mit der with-Syntax erstellt wird, wird das geöffnete Objekt nach Beenden der Anweisung automatisch geschlossen. Wenn Sie die Öffnungsfunktion direkt verwenden, um ein Objekt zu definieren, müssen Sie den Schließvorgang am Ende der Aufgabe manuell ausführen. Im Folgenden wird die Verwendung der integrierten Funktion open und ihrer Dateioperationsattribute veranschaulicht. Erstellen Sie zunächst eine Datei mit dem Namen file-test.py:
# file-test.py with open('test1.txt', 'w') as file: file.write('hello world!')
Der Inhalt der Aufgabe lautet: Erstellen Sie eine Datei mit dem Namen test1.txt im aktuellen Verzeichnis und leeren Sie es. Schreiben Sie nach dem Inhalt der Datei die Zeichenfolge „Hallo Welt!“ in die Datei. Als nächstes verwenden Sie Python3, um die Datei auszuführen:
[dechin@dechin-manjaro os_security]$ python3 file-test.py
[dechin@dechin-manjaro os_security]$ ll
Gesamtnutzung 8
-rw-r--r - - 1 dechin dechin 83 25. Januar 13:43 file-test.py
-rw-r--r-- 1 dechin dechin 12. 25. Januar 13:43 test1.txt
Hier haben wir festgestellt, dass es nach der Ausführung erfolgreich war Die Datei test1.txt wird generiert und ihre Berechtigungen sind auf 644 konfiguriert, was mit der zuvor erstellten Datei-test.py übereinstimmt. Als ich das Implementierungsprinzip der integrierten Funktion open nicht kannte, dachte ich ursprünglich, dass die generierte Dateiberechtigungskonfiguration mit der aktuellen py-Datei übereinstimmt. Nach weiteren Tests wurden die Berechtigungen der py-Datei jedoch auf 440 konfiguriert und die Datei dann erneut ausgeführt:
[dechin@dechin-manjaro os_security]$ chmod 440 file-test.py
[dechin@dechin-manjaro os_security]$ ll
Gesamtnutzung 8
-r--r----- 1 Dechin Dechin 83 25. Januar 13:43 file-test.py
-rw-r--r-- 1 Dechin Dechin 12 25. Januar 13 : 43 test1.txt
[dechin@dechin-manjaro os_security]$ rm test1.txt
[dechin@dechin-manjaro os_security]$ python3 file-test.py
[dechin@dechin-manjaro os_security]$ ll
Gesamtnutzung 8
-r--r----- 1 Dechin Dechin 83 25. Januar 13:43 file-test.py
-rw-r--r-- 1 Dechin Dechin 12. 25. Januar 13:44 test1.txt
Hier können wir aus den Testergebnissen ersehen, dass der Dateityp, der von Pythons integrierter Funktion open generiert wird, nichts mit der Quell-PY-Datei zu tun hat. Informationen dazu, ob für die Ausführung dieser Py-Datei ausführbare Berechtigungen erforderlich sind, finden Sie in diesem Blog.
Verbesserte Methode zur Erstellung von Python-Dateien
Über die fdopen-Bibliothek und die spezielle Berechtigungsspezifikation können wir die Zugriffsberechtigungen der generierten Dateien festlegen:
# fdopen-test.py import os import stat file_name = 'test2.txt' flags = os.O_WRONLY | os.O_CREAT | os.O_EXCL mode = stat.S_IRUSR | stat.S_IWUSR with os.fdopen(os.open(file_name, flags, mode), 'w') as file: file.write('hello world!')
Nach der Ausführung finden wir das im aktuellen Verzeichnis Eine Datei mit dem Namen test2.txt wird generiert und ihre Berechtigungen sind als 600 konfiguriert, verglichen mit dem Modus = stat.S_IRUSR |, den wir im Code festgelegt haben. Hier erklären wir zunächst einige der Parameter: os.O_WRONLY bedeutet Öffnen im Nur-Schreib-Modus, os.O_CREAT bedeutet Erstellen und Öffnen einer neuen Datei, os.O_EXCL bedeutet Melden eines Fehlers, wenn die Datei bereits existiert. Die im Modus konfigurierten Berechtigungen entsprechen jeweils der rwx-Konfiguration, und USR, GRP und OTH verfügen jeweils über unterteilte Konfigurationen für Benutzer, Benutzergruppen und andere Benutzer, sodass wir alle Arten von Berechtigungskonfigurationen durch Ändern der Modusparameter realisieren können.
Wir können versuchen, den Modus im obigen Anwendungsfall anzupassen, indem wir beispielsweise eine ausführbare Berechtigung zu 700:
# fdopen-test.py import os import stat file_name = 'test3.txt' flags = os.O_WRONLY | os.O_CREAT | os.O_EXCL mode = stat.S_IRUSR | stat.S_IWUSR | stat.S_IXUSR with os.fdopen(os.open(file_name, flags, mode), 'w') as file: file.write('hello world!')
# fdopen-test.py import os import stat file_name = 'test4.txt' flags = os.O_WRONLY | os.O_CREAT | os.O_EXCL mode = stat.S_IRUSR | stat.S_IWUSR | stat.S_IRGRP with os.fdopen(os.open(file_name, flags, mode), 'w') as file: file.write('hello world!')
# fdopen-test.py import os import stat file_name = 'test5.txt' flags = os.O_WRONLY | os.O_CREAT | os.O_EXCL mode = stat.S_IRUSR | stat.S_IWUSR | stat.S_IRGRP | stat.S_IROTH with os.fdopen(os.open(file_name, flags, mode), 'w') as file: file.write('hello world!')
[dechin@dechin-manjaro os_security]$ llAus den Ergebnissen können wir ersehen, dass alle generierten Dateien test*.txt gemäß unserer erwarteten Dateiberechtigungskonfiguration generiert werden. Hier werden alle erwarteten Ziele erreicht.Gesamtnutzung 28
-rw-r--r-- 1 Dechin Dechin 269 25. Januar 14:58 fdopen-test.py
-r--r----- 1 Dechin Dechin 84 25. Januar 14:11 Datei- test.py
- rw-r--r-- 1 Dechin Dechin 12. 25. Januar 13:44 test1.txt
-rw------- 1 Dechin Dechin 12. 25. Januar 14:44 test2.txt
-rwx----- - 1 Dechin Dechin 12. 25. Januar 14:48 test3.txt
-rw-r----- 1 Dechin Dechin 12. 25. Januar 14:56 test4.txt
-rw-r- -r-- 1 Dechin Dechin 12. Januar 25 14:58 test5.txt
Das obige ist der detaillierte Inhalt vonSo verwenden Sie fdopen, um Berechtigungen für vom Python-Prozess generierte Dateien zu minimieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Lösung für Erlaubnisprobleme beim Betrachten der Python -Version in Linux Terminal Wenn Sie versuchen, die Python -Version in Linux Terminal anzuzeigen, geben Sie Python ein ...

Bei der Verwendung von Pythons Pandas -Bibliothek ist das Kopieren von ganzen Spalten zwischen zwei Datenrahmen mit unterschiedlichen Strukturen ein häufiges Problem. Angenommen, wir haben zwei Daten ...

Alternative Verwendung von Python -Parameteranmerkungen in der Python -Programmierung, Parameteranmerkungen sind eine sehr nützliche Funktion, die den Entwicklern helfen kann, Funktionen besser zu verstehen und zu verwenden ...

Auswahl der Python-plattformübergreifenden Desktop-Anwendungsentwicklungsbibliothek Viele Python-Entwickler möchten Desktop-Anwendungen entwickeln, die sowohl auf Windows- als auch auf Linux-Systemen ausgeführt werden können ...

Wie lösten Python -Skripte an einem bestimmten Ort die Ausgabe in Cursorposition? Beim Schreiben von Python -Skripten ist es üblich, die vorherige Ausgabe an die Cursorposition zu löschen ...

Warum kann mein Code nicht die von der API zurückgegebenen Daten erhalten? Bei der Programmierung stoßen wir häufig auf das Problem der Rückgabe von Nullwerten, wenn API aufruft, was nicht nur verwirrend ist ...

Wie hört Uvicorn kontinuierlich auf HTTP -Anfragen an? Uvicorn ist ein leichter Webserver, der auf ASGI basiert. Eine seiner Kernfunktionen ist es, auf HTTP -Anfragen zu hören und weiterzumachen ...

Wie erstellt in Python ein Objekt dynamisch über eine Zeichenfolge und ruft seine Methoden auf? Dies ist eine häufige Programmieranforderung, insbesondere wenn sie konfiguriert oder ausgeführt werden muss ...
