Upload File trong lập trình Website với Python
Lập trình web với Python bằng Django

Danh sách bài học
Upload File trong lập trình Website với Python
Nội dung bài viết Học nhanh
Ghi chú
Nội dung bài viết bạn đang xem được update từ tháng 06/2019. Vì vậy sẽ có đôi chút khác biệt giữa VIDEO và NỘI DUNG BÀI VIẾT.
Chúng ta sẽ có nhiều cập nhập hơn về cả bài viết lẫn video trong thời gian tới. Nhớ like / share hoặc đánh giá 5 sao để Kteam có động lực nhé!
Cảm ơn các bạn!
Dẫn nhập
Ở bài trước, Kteam đã hướng dẫn các bạn xong DJANGO SỬ DỤNG MÔ HÌNH MVC
Trong bài này Kteam hướng dẫn cách upload file ảnh vào trang web được làm bằng Django MVC.
Nội dung
Để theo dõi bài này tốt nhất, bạn nên xem qua bài:
- GIỚI THIỆU VỀ PYTHON DJANGO
- TẠO PROJECT VỚI PYTHON DJANGO
- TẠO WEB APP VÀ XỬ LÝ KHI NGƯỜI DÙNG YÊU CẦU TRUY CẬP TRONG PYTHON DJANGO
- SỬ DỤNG TEMPLATE VÀ JINJA TRONG PYTHON DJANGO
- FILE TĨNH VÀ THIẾT KẾ WEB BẰNG BOOTSTRAP TRONG PYTHON DJANGO
- THIẾT KẾ HOÀN CHỈNH BLOG TRONG PYTHON DJANGO
- DÙNG MODEL TẠO BẢNG DATABASE BẰNG NGÔN NGỮ PYTHON
- TƯƠNG TÁC DATABASE BẰNG NGÔN NGỮ PYTHON
- HỆ THỐNG ADMIN TRONG PYTHON DJANGO
- LIỆT KÊ DANH SÁCH BÀI VIẾT TRONG PYTHON DJANGO
- HIỂN THỊ THÔNG TIN BÀI VIẾT TRONG PYTHON DJANGO
- LOẠI BỎ HARDCODED URL TRONG PYTHON DJANGO.
- XỬ LÝ LỖI 404 TRONG PYTHON DJANGO
- DJANGO SỬ DỤNG MÔ HÌNH MVC
Bài này sẽ giới thiệu những nội dung sau:
- Tạo thêm field models để chứa thông tin file ảnh
- Cách lưu trữ ảnh đã upload
- Hiển thị ảnh lên trang web
Tạo thêm field models để chứa thông tin file ảnh
Trước tiên, hãy nhớ chuyển DEBUG = TRUE để tiếp tục phát triển website.
Bây giờ, Kteam muốn mỗi bài viết sẽ có 1 bức ảnh đại diện mỗi bài, nên Kteam sẽ vào models chỉnh Post thêm field image như sau:
Ở đây thì Kteam cho phép field có giá trị null, nguyên nhân là trong các bài trước Kteam đã lỡ tạo 2 bài viết, nếu bây giờ không cho phép null thì sẽ dính lỗi logic vì 2 bài viết trước đó không có ảnh. Nếu không có null thì sẽ hiện lỗi như sau:
Lúc đó, nên chọn 2 thoát ra và chỉnh field mới làm cho phép null.
Lưu ý: Nếu khi chạy makemigrations mà thấy lỗi này thì do thiếu thư viện Pillow, bạn hãy chạy lệnh pip để cài thêm vào.
Sau khi tạo được file migrations, thì dùng lệnh migrate để cập nhật là Database:
Cách lưu trữ ảnh đã upload
Giờ ta thử vô admin, vào post và upload 1 file ảnh lên:
Sau khi upload xong, thử nhấn đường dẫn đến bức ảnh đã upload xem:
Ta sẽ thấy Django sẽ không hiểu được đường dẫn web đó
Giờ ta thử quay lại Project để xem bức ảnh đó ở đâu:
Ta sẽ thấy bức ảnh ngay trong project, có lẽ không nên để bức ảnh lộn xộn như vậy mà nên tập trung vào 1 folder lưu trữ.
Nguyên nhân lỗi ở trên là do Django không thể map đường url bức ảnh và folder chứa ảnh đó. Nhiệm vụ của chúng ta là nên map 2 cái đó lại để Django biết url này nên lấy bức ảnh nào.
- Bước 1: Kteam sẽ tạo ra 1 folder media để chứa các bức ảnh upload, sau đó move ảnh upload lúc nãy vào folder này
- Bước 2: Vào settings.py khai báo đường dẫn url media và folder media
- Bước 3: Ta sẽ map url media và folder media này lại, ta sẽ qua urls.py tổng để khai báo:
- Đầu tiên là import static và settings.
- Tiếp theo, ta sẽ kiểm tra xem Project có DEBUG bằng True không, vì ở chế độ DEBUG ta mới cần map giữa url media và folder media. Còn khi deploy lên server, thì web server sẽ chịu trách nhiệm các đường dẫn file ảnh, Django không cần thực hiện cái map này.
- Nếu DEBUG là True, urlpatterns sẽ thêm 1 url static, đó là đường dẫn /media/ mà ở đây là giá trị của biến MEDIA_URL, folder static chính là folder media mà mình xử lý ở biến MEDIA_ROOT.
Sau khi restart server, ta thử vào lại đường dẫn hình:
Ta thấy Django đã có đường dẫn /media/ và nó có thể lấy bức ảnh 1.jpg tương ứng đường dẫn /media/1.jpg.
Lưu ý: Nếu upload file trùng tên với một file đã có trong kho lưu trữ thì Django sẽ tự tạo 1 đoạn mã sau để phân biệt, Kteam sẽ upload chung 1 file ở bài viết thứ 2
Hiển thị ảnh lên trang web
Như vậy, sau khi upload xong, Kteam sẽ hiển thị bức ảnh đó ở mỗi bài viết như sau:
- template post.html:
- template blog.html:
Kteam sẽ phải dùng post.image.url để lấy được giá trị đường dẫn url bức ảnh rồi gán mà src của tag img.
Kết
Trong bài này, chúng ta đã tìm hiểu cách Upload File trong lập trình Website với Python.
Bài sau chúng ta sẽ cùng tìm hiểu về cách TẠO FORM ĐĂNG KÝ TÀI KHOẢN.
Cảm ơn các bạn đã theo dõi bài viết. Hãy để lại bình luận hoặc góp ý của mình để phát triển bài viết tốt hơn. Và đừng quên “Luyện tập – Thử Thách – Không ngại khó”
Tải xuống
Tài liệu
Nhằm phục vụ mục đích học tập Offline của cộng đồng, Kteam hỗ trợ tính năng lưu trữ nội dung bài học Upload File trong lập trình Website với Python dưới dạng file PDF trong link bên dưới.
Ngoài ra, bạn cũng có thể tìm thấy các tài liệu được đóng góp từ cộng đồng ở mục TÀI LIỆU trên thư viện Howkteam.com
Đừng quên like và share để ủng hộ Kteam và tác giả nhé!

Thảo luận
Nếu bạn có bất kỳ khó khăn hay thắc mắc gì về khóa học, đừng ngần ngại đặt câu hỏi trong phần bên dưới hoặc trong mục HỎI & ĐÁP trên thư viện Howkteam.com để nhận được sự hỗ trợ từ cộng đồng.
Khóa học
Lập trình web với Python bằng Django
Lập trình web với Python bằng Django
SystemCheckError: System check identified some issues:
ERRORS:
?: (urls.E008) The custom handler404 view 'home.views.error' could not be imported.
HINT: Could not import 'home.views.error'. View does not exist in module home.views.
?: (urls.E008) The custom handler500 view 'home.views.error' could not be imported.
HINT: Could not import 'home.views.error'. View does not exist in module home.views.
lỗi này là bị gì z? Có ai biết cahs khắc phục không?
cho em hỏi lỗi này sửa sao vậy ạ
IntegrityError at /admin/blog/post/1/change/
Traceback Switch to copy-and-paste view
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\db\backends\utils.py
in_execute
▶ Local vars
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\db\backends\sqlite3\base.py
inexecute
▶ Local vars
The above exception (NOT NULL constraint failed: blog_post.date) was the direct cause of the following exception:
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\core\handlers\exception.py
ininner
▶ Local vars
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\core\handlers\base.py
in_get_response
IntegrityError at /admin/blog/post/1/change/
Traceback Switch to copy-and-paste view
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\db\backends\utils.py
in_execute
▶ Local vars
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\db\backends\sqlite3\base.py
inexecute
▶ Local vars
The above exception (NOT NULL constraint failed: blog_post.date) was the direct cause of the following exception:
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\core\handlers\exception.py
ininner
▶ Local vars
C:\Users\DELL\AppData\Local\Programs\Python\Python37-32\lib\site-packages\django\core\handlers\base.py
in_get_response
{% for post in Posts %} <h4>{{post.date|date:"d-m-Y"}}<a href="/redirect?Id=bPkSKQqMZ9erlLi6p21Q4A%3d%3d" url 'post' post.id %}">{{post.title}}</a></h4> <img src="{{post.image.url}}" width="500px" height="300px" /> {% endfor %}
Đoạn trên mình chạy sẽ có lỗi.
Sửa lại như này thì sẽ được ạ:
ad cho e hỏi e muốn upload video lên thì làm như nào ạ