Mengesahkan Kebenaran Tulis Pengguna untuk Direktori dalam C#
Sebelum melakukan sebarang operasi tulis sistem fail, adalah penting untuk mengesahkan akses tulis pengguna ke direktori sasaran. Artikel ini membentangkan kaedah C# yang boleh dipercayai untuk semakan penting ini.
Batasan Kaedah Sedia Ada
Pendekatan tradisional, seperti menggunakan Directory.GetAccessControl()
, mungkin tidak boleh dipercayai. Walaupun mereka mungkin menunjukkan akses tulis, mereka sering membuang UnauthorizedAccessException
jika pengguna tidak mempunyai kebenaran untuk melihat tetapan keselamatan direktori.
Penyelesaian Teguh: IsDirectoryWritable()
Kaedah kami yang dipertingkatkan, IsDirectoryWritable()
, secara langsung menguji akses tulis tanpa bergantung pada pengambilan kebenaran yang berpotensi bermasalah:
<code class="language-csharp">public bool IsDirectoryWritable(string dirPath, bool throwIfFails = false) { try { using (FileStream fs = File.Create( Path.Combine( dirPath, Path.GetRandomFileName() ), 1, FileOptions.DeleteOnClose) ) { } return true; } catch { if (throwIfFails) throw; else return false; } }</code>
Fungsi ini mencipta fail sementara dalam direktori yang ditentukan. Penciptaan yang berjaya mengesahkan akses tulis. Fungsi ini mengendalikan pengecualian dengan anggun, mengembalikan false
secara lalai, tetapi menawarkan pilihan throwIfFails
untuk pengendalian ralat yang lebih terkawal.
Kelebihan Utama:
Pendekatan ini menawarkan beberapa kelebihan berbanding kaedah sedia ada:
Kesimpulan:
Kaedah IsDirectoryWritable()
menawarkan cara yang diperkemas dan boleh dipercayai untuk mengesahkan akses tulis kepada direktori dalam C#, meningkatkan keteguhan operasi pengendalian fail anda. Ia merupakan alternatif yang lebih baik daripada kaedah yang bergantung pada pengambilan kebenaran yang mungkin terdedah kepada ralat.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menyemak Akses Tulis ke Direktori dengan Amanah dalam C#?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!