<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 閱讀(1536) 評論(0)  編輯  收藏 所屬分類: Python
    主站蜘蛛池模板: 免费看美女裸露无档网站| 午夜国产羞羞视频免费网站| 性xxxx黑人与亚洲| 波多野结衣中文一区二区免费| 精品无码一级毛片免费视频观看 | 亚洲av无码片在线观看| 日韩精品免费一区二区三区| 四虎国产精品免费永久在线| 亚洲午夜精品久久久久久app| 中文字幕亚洲日本岛国片| 99久久国产热无码精品免费 | 亚洲国产精品嫩草影院| 亚洲精品无码AV人在线播放| 免费电影在线观看网站| 97在线免费视频| 亚洲精品无码人妻无码| 亚洲伦另类中文字幕| 伊在人亚洲香蕉精品区麻豆| 91免费在线播放| 中文字幕av免费专区| 亚洲AV无码国产剧情| 337p日本欧洲亚洲大胆色噜噜| 免费va在线观看| a毛片基地免费全部视频| 免费视频一区二区| 国产亚洲精品美女久久久久| 亚洲精品免费在线| 国产AV无码专区亚洲Av| 免费在线观看亚洲| 成人性生交大片免费看午夜a| 在线观看的免费网站无遮挡| 国产精品成人啪精品视频免费| 亚洲综合精品伊人久久| 亚洲资源在线视频| 亚洲精品无码不卡在线播HE| 免费一级毛片在级播放| 成人a免费α片在线视频网站| 亚洲免费在线视频播放| 久久久久免费精品国产小说| 中文字幕无线码免费人妻| 免费国产黄网站在线观看动图|