<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Sealyu

    --- 博客已遷移至: http://www.sealyu.com/blog

      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
      618 隨筆 :: 87 文章 :: 225 評論 :: 0 Trackbacks

    Some interesting examples on how to handle file uploads using Django:

    • Code snippet posted on Djangosnippets. The file is saved by declaring a save() method in the form class. This method is invoked when calling form.save(), which is standard Django newforms practice. (Note that this snipped uses clean_data. As of Django version 0.96, clean_data has been renamed to cleaned_data, so you will have to change the code or it won’t work)
    • Django image upload and validation. The author uses a model for the file and its related data. The uploaded file is saved by calling the save_FOO_file method. (This method is automatically provided by Django for fields declared as models.ImageField or models.FileField in the model. See the db-api documentation.)
    • Django image upload, form_for_instance and monkey-patching. The example code creates a form class from request.user by calling form_for_instance. The resulting class in then monkey-patched to insert the avatar image validation code. (Although the code is interesting the monkey patch seems unnecessary. I wouldn’t mind inserting the avatar validation method in a UserProfileForm class derived from form.Forms. The code would be certainly clearer: I think KISS takes precedence over DRY in this case.)

    Interesting, there seems to be no easy way of limiting the uploaded file size. The file can be rejected at validation time, but the data would have already been transfered.

    A file upload recipe

    After reading those posts, I think that a good recipe for handling file uploads in Django would be:

    • Write a django model for the uploaded file and its related data. Using a Django model makes sense, because it is usually necessary for the application to keep track of the uploaded files.
    • Write a subclass of form.Forms and declare a clean_FOO method for each models.FileInput or models.ImageInput fields declared in the model class. These clean_FOO methods are used to validate the uploaded files.
    • use a django view to receive the POST data, or display the form if no data is posted or errors are found.
    • validate the uploaded file or files by triggering the standard django newforms validation mechanism: is_valid().
    • save the file or files getting the data directly from the request.FILES object, by writing a save() method for the subclassed form or by calling save_FOO_file for the model instance.

    A simpler way to upload a file

    The following short Django example uses no data models, does no data validation, and saves the file directly to disk using python standard file functions. It is just a simple test I wrote to get familiar with the request.FILES object. This is not production code: it could be used to execute an arbitrary script on the server.
    The directory where the file is to be saved must be writable by the user that is running the Django server script. (The example uses MEDIA_ROOT as defined in settings.py.)

    file: views.py

    1. from django import http  
    2. from django import newforms as forms  
    3. from django.shortcuts import render_to_response  
    4. from djangotest.settings import MEDIA_ROOT  
    5.    
    6.    
    7. class SimpleFileForm(forms.Form):  
    8.     file = forms.Field(widget=forms.FileInput, required=False)  
    9.    
    10.    
    11. def directupload(request):  
    12.     """ 
    13.     Saves the file directly from the request object.  
    14.     Disclaimer:  This is code is just an example, and should 
    15.     not be used on a real website.  It does not validate 
    16.     file uploaded:  it could be used to execute an  
    17.     arbitrary script on the server.  
    18.     """  
    19.    
    20.     template = 'fileupload.html'  
    21.    
    22.     if request['method'] == 'POST':  
    23.         if 'file' in request.FILES:  
    24.             file = request.FILES['file']  
    25.    
    26.             # Other data on the request.FILES dictionary:  
    27.             #   filesize = len(file['content'])<br />  
    28.             #   filetype = file['content-type']   
    29.    
    30.             filename = file['filename']  
    31.    
    32.             fd = open('%s/%s' % (MEDIA_ROOT, filename), 'wb')  
    33.             fd.write(file['content'])  
    34.             fd.close()  
    35.    
    36.             return http.HttpResponseRedirect(' upload_success.html')  
    37.     else:  
    38.         # display the form  
    39.         form = SimpleFileForm()  
    40.         return render_to_response(template, { 'form': form })  
    41.    

    file: fileupload.html

    1. {% extends "base.html" %}  
    2.    
    3. {% block body  %}  
    4.      <h1>Upload a file</h1>  
    5.      <form action="." method="post" enctype="multipart/form-data">  
    6.              {{ form }}  
    7.              <input type="submit" value="Upload" />  
    8.      </form>  
    9. {% endblock %} 
    posted on 2008-09-22 23:08 seal 閱讀(1542) 評論(0)  編輯  收藏 所屬分類: Python
    主站蜘蛛池模板: 久久九九AV免费精品| 中文字幕av无码不卡免费| 1000部拍拍拍18免费网站| 久久亚洲伊人中字综合精品| av网站免费线看| 亚洲欧洲日产国码无码网站| 88xx成人永久免费观看| 亚洲成A∨人片在线观看不卡| 9i9精品国产免费久久| 亚洲人成影院在线无码按摩店| 精品多毛少妇人妻AV免费久久| 亚洲一区二区三区香蕉| av永久免费网站在线观看| 国产亚洲无线码一区二区| 免费人成视频在线观看网站| 四虎成人免费大片在线| 亚洲熟女综合色一区二区三区 | 亚洲国产精品一区第二页| 中文字幕在线成人免费看| 亚洲天天做日日做天天看| 国产免费一区二区三区| 亚洲一线产区二线产区区| 亚洲成av人片在线观看天堂无码| 亚洲一区二区三区免费| 亚洲欧洲在线观看| 在线免费不卡视频| 一级一级一片免费高清| 午夜dj免费在线观看| 免费一级全黄少妇性色生活片| 亚洲av无码不卡| 成年人视频在线观看免费| 黄页免费视频播放在线播放| 亚洲国产精品无码久久久秋霞2 | 中文字幕av无码无卡免费| 国产亚洲精品国产福利在线观看| 亚洲人妻av伦理| 亚洲三级在线免费观看| 无人视频免费观看免费视频| 亚洲视频免费在线看| gogo全球高清大胆亚洲| 18级成人毛片免费观看|