zoukankan      html  css  js  c++  java
  • django+vue 分片上传(前后端分离)

    分片上传:

    setting.py

    #图片上传
    MEDIA_ROOT = os.path.join(BASE_DIR, 'static')
    MEDIA_URL = '/static/media/'
    

    view.py

    class Upload(APIView):
        def post(self, request):
            data = {}
            data['code']=200
            
            chunk = request.data['chunkNumber']
            upload_file=request.data['file']
            identifier = request.data['identifier']
            file_name='%s%s' % (identifier,chunk)
            with open('static/media/'+file_name,'wb') as tem_file:
                for buf in upload_file.chunks():
                    tem_file.write(buf)
            return Response(data)
    
    class Join_file(APIView):
        def post(self,request):
            print(request.data)
            chunk=1
            with open('static/media/'+request.data['filename'],'wb') as tar_file:
                while True:
                    try:
                        filename = 'static/media/'+request.data['uniquefile']+str(chunk)
                        tem_file=open(filename,'rb')
                        tar_file.write(tem_file.read())
                        tem_file.close()
                    except IOError:
                        break
                    chunk+=1
                    os.remove(filename)
            return Response({'data':200})
    

    urls.py

    from django.urls import path
    from . import views
    urlpatterns = [
        path('upload/', views.Upload.as_view(), name='upload'),
        path('join_file/', views.Join_file.as_view(), name='join_file'),
    ]
    
    

    vue

    <template>
      <uploader :options="options" class="uploader-example" @file-success="fileSuccess">
        <uploader-unsupport></uploader-unsupport>
        <uploader-drop>
          <p>Drop files here to upload or</p>
          <uploader-btn v-on:finish="fileSuccess">select files</uploader-btn>
          <uploader-btn :attrs="attrs">select images</uploader-btn>
          <uploader-btn :directory="true">select folder</uploader-btn>
        </uploader-drop>
        <uploader-list></uploader-list>
      </uploader>
    </template>
    
    <script>
      import axios from 'axios'
      export default {
        name:'Upload',
        data () {
          return {
            options: {
              // https://github.com/simple-uploader/Uploader/tree/develop/samples/Node.js
              target: this.$api+'api/user/upload/',
              testChunks: false,
              chunkSize: '2048000' 
            },
            attrs: {
              accept: 'image/*'
            },
          }
        },
        methods: {
          fileSuccess(rootFile, file, message,chunk){
            console.log(rootFile, file, message,chunk)
            if(JSON.parse(message).code==200){
              console.log('ok')
              let form = new FormData()
              form.append('filename',rootFile.name)
              form.append('uniquefile',rootFile.uniqueIdentifier)
              axios({
                url:this.$api+'api/user/join_file/',
                method:'post',
                data:form
              }).then((res)=>{
                console.log(res.data)
              })
            }
          },
          progress(e){
            console.log(e)
          }
        }
      }
    </script>
    
    <style>
      .uploader-example {
         880px;
        padding: 15px;
        margin: 40px auto 0;
        font-size: 12px;
        box-shadow: 0 0 10px rgba(0, 0, 0, .4);
      }
      .uploader-example .uploader-btn {
        margin-right: 4px;
      }
      .uploader-example .uploader-list {
        max-height: 440px;
        overflow: auto;
        overflow-x: hidden;
        overflow-y: auto;
      }
    </style>
    
  • 相关阅读:
    Ubuntu
    SSH
    Markdown
    Mac OS 上的一些骚操作
    Linux Bash
    JConsole
    IDEA
    Groovy
    Github
    Git
  • 原文地址:https://www.cnblogs.com/lichaoya/p/13755052.html
Copyright © 2011-2022 走看看