<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 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      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 閱讀(1535) 評論(0)  編輯  收藏 所屬分類: Python
    主站蜘蛛池模板: 精品久久亚洲中文无码| 久久久久亚洲av无码专区蜜芽 | 免费人成网站在线观看10分钟| 国产精品亚洲综合专区片高清久久久| 在线观看亚洲网站| 四虎成人精品在永久免费| 午夜亚洲国产理论片二级港台二级| 67194成是人免费无码| 亚洲妇女无套内射精| 免费人成视频在线观看不卡| 香港一级毛片免费看| 亚洲一级特黄无码片| 在线看片免费人成视频久网下载 | 亚洲av日韩综合一区久热| 午夜精品在线免费观看| 色婷婷亚洲一区二区三区| 亚洲M码 欧洲S码SSS222| 中文字幕永久免费| 夜夜亚洲天天久久| 99久久久国产精品免费无卡顿| 亚洲日韩国产精品乱-久| 四虎影视精品永久免费网站| 久久久受www免费人成| 亚洲情a成黄在线观看动漫尤物| h片在线免费观看| 国产亚洲一卡2卡3卡4卡新区| 免费一级毛片在线观看| 国产精品青草视频免费播放| 亚洲人成网站在线播放影院在线| 亚洲免费在线观看视频| 老妇激情毛片免费| 亚洲人成影院在线| 日本黄色免费观看| 免费成人在线电影| 亚洲乱码国产乱码精华| 亚洲女久久久噜噜噜熟女| 欧洲乱码伦视频免费| 成人一级免费视频| 亚洲乱码一二三四五六区| 亚洲成人影院在线观看| 91精品视频免费|