[1.1.X] Fixed #11782 -- Added some Sphinx metadata to the file uploads documentation. Thanks to timo for the patch.
Backport of r12562 from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.1.X@12566 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
f7b415869c
commit
fbe455e1ac
|
@ -9,15 +9,15 @@ File Uploads
|
||||||
.. versionadded:: 1.0
|
.. versionadded:: 1.0
|
||||||
|
|
||||||
When Django handles a file upload, the file data ends up placed in
|
When Django handles a file upload, the file data ends up placed in
|
||||||
``request.FILES`` (for more on the ``request`` object see the documentation for
|
:attr:`request.FILES <django.http.HttpRequest.FILES>` (for more on the
|
||||||
:ref:`request and response objects <ref-request-response>`). This document
|
``request`` object see the documentation for :ref:`request and response objects
|
||||||
explains how files are stored on disk and in memory, and how to customize the
|
<ref-request-response>`). This document explains how files are stored on disk
|
||||||
default behavior.
|
and in memory, and how to customize the default behavior.
|
||||||
|
|
||||||
Basic file uploads
|
Basic file uploads
|
||||||
==================
|
==================
|
||||||
|
|
||||||
Consider a simple form containing a ``FileField``::
|
Consider a simple form containing a :class:`~django.forms.FileField`::
|
||||||
|
|
||||||
from django import forms
|
from django import forms
|
||||||
|
|
||||||
|
@ -25,14 +25,17 @@ Consider a simple form containing a ``FileField``::
|
||||||
title = forms.CharField(max_length=50)
|
title = forms.CharField(max_length=50)
|
||||||
file = forms.FileField()
|
file = forms.FileField()
|
||||||
|
|
||||||
A view handling this form will receive the file data in ``request.FILES``, which
|
A view handling this form will receive the file data in
|
||||||
is a dictionary containing a key for each ``FileField`` (or ``ImageField``, or
|
:attr:`request.FILES <django.http.HttpRequest.FILES>`, which is a dictionary
|
||||||
other ``FileField`` subclass) in the form. So the data from the above form would
|
containing a key for each :class:`~django.forms.FileField` (or
|
||||||
|
:class:`~django.forms.ImageField`, or other :class:`~django.forms.FileField`
|
||||||
|
subclass) in the form. So the data from the above form would
|
||||||
be accessible as ``request.FILES['file']``.
|
be accessible as ``request.FILES['file']``.
|
||||||
|
|
||||||
Note that ``request.FILES`` will only contain data if the request method was
|
Note that :attr:`request.FILES <django.http.HttpRequest.FILES>` will only
|
||||||
``POST`` and the ``<form>`` that posted the request has the attribute
|
contain data if the request method was ``POST`` and the ``<form>`` that posted
|
||||||
``enctype="multipart/form-data"``. Otherwise, ``request.FILES`` will be empty.
|
the request has the attribute ``enctype="multipart/form-data"``. Otherwise,
|
||||||
|
``request.FILES`` will be empty.
|
||||||
|
|
||||||
Most of the time, you'll simply pass the file data from ``request`` into the
|
Most of the time, you'll simply pass the file data from ``request`` into the
|
||||||
form as described in :ref:`binding-uploaded-files`. This would look
|
form as described in :ref:`binding-uploaded-files`. This would look
|
||||||
|
@ -54,16 +57,16 @@ something like::
|
||||||
form = UploadFileForm()
|
form = UploadFileForm()
|
||||||
return render_to_response('upload.html', {'form': form})
|
return render_to_response('upload.html', {'form': form})
|
||||||
|
|
||||||
Notice that we have to pass ``request.FILES`` into the form's constructor; this
|
Notice that we have to pass :attr:`request.FILES <django.http.HttpRequest.FILES>`
|
||||||
is how file data gets bound into a form.
|
into the form's constructor; this is how file data gets bound into a form.
|
||||||
|
|
||||||
Handling uploaded files
|
Handling uploaded files
|
||||||
-----------------------
|
-----------------------
|
||||||
|
|
||||||
The final piece of the puzzle is handling the actual file data from
|
The final piece of the puzzle is handling the actual file data from
|
||||||
``request.FILES``. Each entry in this dictionary is an ``UploadedFile`` object
|
:attr:`request.FILES <django.http.HttpRequest.FILES>`. Each entry in this
|
||||||
-- a simple wrapper around an uploaded file. You'll usually use one of these
|
dictionary is an ``UploadedFile`` object -- a simple wrapper around an uploaded
|
||||||
methods to access the uploaded content:
|
file. You'll usually use one of these methods to access the uploaded content:
|
||||||
|
|
||||||
``UploadedFile.read()``
|
``UploadedFile.read()``
|
||||||
Read the entire uploaded data from the file. Be careful with this
|
Read the entire uploaded data from the file. Be careful with this
|
||||||
|
|
Loading…
Reference in New Issue