加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

【django】 接收所有文件,前端展示文件(包括视频,文件,图片

发布时间:2020-12-15 17:09:12 所属栏目:大数据 来源:网络整理
导读:如果是后台上传文件: setting配置:STATIC_URL = ' /static/ ' STATICFILES_DIRS = [ os.path.join(BASE_DIR, static ),os.path.join(BASE_DIR,1)">" media " # Django用户上传的都叫media文件 MEDIA_URL = /media/ " media配置,用户上传的文件都默认放在这
如果是后台上传文件:
setting配置:
STATIC_URL = '/static/'
STATICFILES_DIRS = [
    os.path.join(BASE_DIR,static),os.path.join(BASE_DIR,1)">"media"# Django用户上传的都叫media文件
MEDIA_URL = /media/"
 media配置,用户上传的文件都默认放在这个文件夹下
MEDIA_ROOT = os.path.join(BASE_DIR,)


model的配置:
 img = models.FileField(upload_to=img/",verbose_name=图片")
接收任何文件的前端代码:
<!DOCTYPE html>
<html lang=en">
<head>
    <meta charset=UTF-8">
    <title>Title</title>
</head>
<body>
<form method=post" action=/upload/" enctype=multipart/form-data" target=ifm1">


    <input type=file" name=" id="/>


    <input type=button" value=提交" onclick=upload()"/>
</form>
<br>
<br>
<br>
<br>
<div>显示图片
    <img id=images">
</div>
<br>
<br>
<br>
<br>
<div>显示路径
    <a href="" id=imagess">链接</a>
</div>


</div>
<br>
<br>
<br>
<br>
<div>
    {    href="/static/img/TC代码.txt" #}
    <a id=up"> 下载文件</a>
</div>


<script src=https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js"></script>

<script>
    function upload() {
        var formData = new FormData();
        var file = document.getElementById().files[0];
        formData.append(,file);
        $.ajax({
            url: upload/json上传文件无需缓存
            processData: false,1)">用于对data参数进行序列化处理 这里必须false
            contentType: false,//必须*/
            success: function (data) {
                console.log(22#images").attr(src#imagesshref#up").on(clickhttp://127.0.0.1:8000/down/get<a></a>);

                $a.attr();
                $(body).append($a);
                $a[0].click();
                $a.remove();
            }

        })

    });
</script>
</body>
</html>
增加任何文件的后端接口代码:

from rest_framework.views import APIView
from django.shortcuts  render,redirect,HttpResponse
from dal  models
from django.http  JsonResponse


class ImageShow(APIView):

    def post(self,request):
        name = str(request.data.get(name))
        message = {}

        img_url  = /static/img/{}.format(name)

        obj = models.Car.objects.filter(img_url=img_url).first()
        if obj :

            message[code'] = 200
            message[message'] = img_url  返还路径
            return JsonResponse(message)
下载文件后端:
from django.utils.http  urlquote
 JsonResponse,FileResponse,StreamingHttpResponse


 fileShow(APIView):

     get(self,request):
        message = {}
        file = open(media/img/TC代码.txt',1)">rb')    字符串替换成文件 
        print( file_names = file.name.split('/')[-1]
         print("file_names",file_names)

        response = FileResponse(file)
        response[Content-Type'] = application/octet-stream

        response[Content-Dispositionattachment;filename={}".format(urlquote(TC代码.txt"))  字符串替换成下载文件
        print(response)
        return response

?

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读