Rumah >pembangunan bahagian belakang >Tutorial Python >Kemahiran memuat naik fail dalam rangka kerja Django
Dalam beberapa tahun kebelakangan ini, aplikasi web telah menjadi semakin popular, dan kebanyakannya memerlukan fungsi muat naik fail. Dalam rangka kerja Django, tidak sukar untuk melaksanakan fungsi memuat naik fail, tetapi dalam pembangunan sebenar, kami juga perlu memproses fail yang dimuat naik Operasi lain termasuk menukar nama fail, mengehadkan saiz fail dan isu lain. Artikel ini akan berkongsi beberapa teknik muat naik fail dalam rangka kerja Django.
1. Item muat naik fail konfigurasi
Dalam projek Django, untuk mengkonfigurasi muat naik fail, anda perlu mengkonfigurasinya dalam fail settings.py. Di bawah ini kami memperkenalkan beberapa item konfigurasi penting.
Laluan muat naik fail
Dalam settings.py, kami boleh menentukan laluan untuk menyimpan fail yang dimuat naik, seperti berikut:
MEDIA_ROOT = os.path.join(BASE_DIR, 'uploads')
Dalam item konfigurasi ini, kami menentukan Direktori akar untuk menyimpan fail yang dimuat naik ialah muat naik dan laluan fail media dikira relatif kepada direktori tempat fail settings.py berada. Kami juga boleh menambah peraturan URL yang sepadan dalam urls.py projek Django supaya pengguna boleh mendapatkan fail yang dimuat naik dengan mengakses URL.
Format fail yang disokong
Kawalan format fail ialah kandungan yang sangat penting Kami boleh menentukan format fail yang dimuat naik melalui item konfigurasi berikut.
ALLOWED_FILE_TYPES = ['jpg', 'jpeg', 'png', 'gif', 'pdf']
Perhatikan bahawa kami mesti menukar semua format fail kepada huruf kecil.
Had saiz fail
Rangka kerja Django mengehadkan saiz semua fail kepada 2.5MB secara lalai. Jika kami perlu mengubah suai nilai had ini, kami boleh mengubah suainya dalam item konfigurasi settings.py.
MAX_UPLOAD_SIZE = 10485760 # 10MB
Dalam konfigurasi ini kami mengehadkan saiz fail muat naik maksimum kepada 10MB.
2. Muat naik fail
Kami boleh memuat naik fail melalui komponen borang Django. Berikut ialah contoh borang muat naik fail ringkas:
<form method="POST" enctype="multipart/form-data"> {% csrf_token %} <input type="file" name="document" accept=".pdf"> <input type="submit" value="Submit"> </form>
Perhatikan bahawa atribut enctype mestilah multipart/form-data untuk menyokong muat naik fail.
Dalam fungsi paparan, kita boleh menggunakan kaedah request.FILES.get() untuk mendapatkan fail yang dimuat naik. Kaedah ini mengembalikan objek fail. Berikut ialah contoh mudah:
def upload(request): if request.method == 'POST': file = request.FILES.get('document') if file: handle_uploaded_file(file) messages.success(request, '上传成功') return redirect('home') else: messages.error(request, '上传失败') return redirect('upload') else: return render(request, 'upload.html')
Dalam contoh ini, kita mula-mula mendapatkan objek fail yang dimuat naik dan kemudian memanggil fungsi handle_uploaded_file() untuk menyimpannya ke laluan yang ditentukan. Sekiranya tiada fail yang dimuat naik, kami boleh menggesa mesej ralat kepada pengguna melalui modul mesej.
3. Penamaan Fail
Untuk mengurus fail yang dimuat naik ke pelayan dengan lebih baik, kami mengesyorkan menamakan fail yang dimuat naik dengan nama fail unik yang mengandungi cap waktu. Berikut ialah contoh mudah:
def handle_uploaded_file(file): date = datetime.now().strftime("%Y%m%d%H%M%S") filename = f"{date}_{file.name}" path = os.path.join(MEDIA_ROOT, filename) with open(path, 'wb+') as destination: for chunk in file.chunks(): destination.write(chunk)
Pertama, kami menggunakan modul datetime untuk mendapatkan tarikh dan masa semasa dan menukarnya kepada format rentetan. Kami kemudian menggabungkan cap masa ini dengan nama fail asal untuk menjana nama fail baharu. Akhir sekali, kami menggabungkan nama fail baharu dengan laluan ke fail yang dimuat naik dan menulis kandungan fail yang dimuat naik ke fail menggunakan kaedah chunks() objek fail.
4. Saiz fail
Untuk mengelakkan masalah pelayan, kami perlu mengehadkan saiz fail yang dimuat naik. Berikut ialah fungsi semakan saiz fail ringkas:
def check_file_size(file): if file.size > MAX_UPLOAD_SIZE: raise ValidationError(f'上传文件大小最大为 {MAX_UPLOAD_SIZE / 1048576} MB')
Dalam fungsi ini, kami menyemak sama ada saiz fail yang dimuat naik melebihi saiz muat naik maksimum. Jika melebihi, kami membuang pengecualian ValidationError dan menggesa pengguna. Kendalikan pengecualian ini dalam fungsi paparan:
def upload(request): if request.method == 'POST': file = request.FILES.get('document') if file: try: check_file_size(file) except ValidationError as e: messages.error(request, e) return redirect('upload') else: handle_uploaded_file(file) messages.success(request, '上传成功') return redirect('home') else: messages.error(request, '上传失败') return redirect('upload') else: return render(request, 'upload.html')
Dengan cara ini, kita boleh mempunyai kawalan yang lebih baik ke atas saiz fail yang dimuat naik.
Ringkasan:
Atas ialah kandungan terperinci Kemahiran memuat naik fail dalam rangka kerja Django. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!