zoukankan      html  css  js  c++  java
  • django 实现上传文件功能

    需求:自己写一个文件上传功能

    代码:

    urls.py

    from django.conf.urls import url
    from django.contrib import admin
    from app01 import views
    
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^upload.html$', views.upload),
    ]
    

    views.py

    from django.shortcuts import render
    from django.shortcuts import redirect
    from django.shortcuts import HttpResponse
    from app01 import models
    import os
    
    #实现文件上传功能
    def upload(request):
        if request.method == 'GET':
            return render(request,'upload.html')
        elif request.method == 'POST':
            obj = request.FILES.get('fafafa')
            f = open(os.path.join('upload',obj.name),'wb')
            for line in obj.chunks():
                f.write(line)
            f.close()
            return HttpResponse('上传成功')
    

    upload.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
    <form action="/upload.html" method="POST" enctype="multipart/form-data">
        {% csrf_token %}
        <input type="file" name="fafafa" />
        <input type="submit" value="上传" />
    </form>
    </body>
    </html>

    运行结果:


     文件上传:

      -普通上传

      -自定义页面上传按钮

      -基于Form做上传

      -Ajax上传文件(后补)

    升级版

    settings.py

    STATIC_URL = '/static/'
    STATICFILES_DIRS = (
        os.path.join(BASE_DIR,'static'),
    ) 

    urls.py

    from django.conf.urls import url
    from django.contrib import admin
    from app01 import views
    
    urlpatterns = [
        url(r'^admin/', admin.site.urls),
        url(r'^upload.html$', views.upload),
    ]
    

    views.py

    from django.shortcuts import render
    from django.shortcuts import HttpResponse
    from django.forms import fields
    from django import forms
    
    
    class UploadForm(forms.Form):
        user = fields.CharField()
        img = fields.FileField()
    
    def upload(request):
        if request.method == 'GET':
            return render(request,'upload.html')
        else:
            # obj = UploadForm(request.POST,request.FILES)
            # if obj.is_valid():
            #     user = obj.cleaned_data['user']
            #     img = obj.cleaned_data['img']
            user = request.POST.get('user')
            img  = request.FILES.get('img')
            # img是对象(文件大小,文件名称,文件内容。。。)
            print(img.name)
            print(img.size)
            f = open(img.name,'wb')
            for line in img.chunks():
                f.write(line)
            f.close()
            return HttpResponse('...')
    

    upload.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body>
        <form action="/upload.html" method="POST" enctype="multipart/form-data">
            {% csrf_token %}
            <input type="text" name="user" />
            <div style="position: relative">
                <a>NB上传</a>
                <input type="file" name="img" style="opacity: 0;position:absolute;top:0;left: 0;" />
            </div>
            <input type="submit" value="提交" />
        </form>
    </body>
    </html>
    

    运行效果:

  • 相关阅读:
    C# 使用EWS 读取 Exchange 未读邮件并设置为已读
    .NET 操作 Exchange示例
    Elsa-Core 工作流 使用代码启动审批流或触发审批任务
    Elsa-Core-workflow 从代码启动指定工作流
    .NET CORE 开源工作流 elsa-core 基础使用示例
    文档翻译经验分享(Markdown)
    Orchard Core 开发示例教程
    VMware 与 Hyper-v 并存, 可同时运行 非启动项
    SmtpException: Failure sending mail. ---> System.InvalidOperationException: Asynchronous operations are not allowed in this context.
    Linux (Deppin ,Ubuntu )开发环境配置,VUE & dotnetcore 解决 yarn 找不到问题
  • 原文地址:https://www.cnblogs.com/nulige/p/6582355.html
Copyright © 2011-2022 走看看