Django+七牛上传+查看+下载文件相关函数,新整理未完全测试

时间:2022-09-25 09:18:42

M

class File(models.Model):  # 文档模型
name = models.CharField(max_length=255)
staff = models.ForeignKey('Staff')
qiniu_name = models.CharField(max_length=255)
remark = models.CharField(max_length=255, default='')

Form

class UploadStafffile(forms.Form):  # 员工上传文件的名字,员工id,员工的备注
name = forms.CharField()
staff = forms.IntegerField()
remark = forms.CharField()
data = forms.FileField() class StaffAllfile(forms.Form):
id = forms.IntegerField() class DownloadStafffile(forms.Form):
qiniu_name = forms.CharField

V

# -*- coding: utf-8 -*-
from __future__ import unicode_literals import base64
import datetime
import json
import random
import string import requests
from django.http import HttpResponse, HttpResponseBadRequest
from django.shortcuts import redirect
from qiniu import Auth
from qiniu.utils import urlsafe_base64_encode from basic import models, forms QINIU = {'access_key': 'SDbdxmtksVbzc6iZHh0YDX6yFbxIMegm_yqP0wqu',
'secret_key': 'cqhR4eMnt_-M0l2NpiBEE02RB9guJxRl_0H3000G', 'bucket_name': 'schoolsalary'} # 上传自命名文档
def upload_staff_file(request):
form = forms.UploadStafffile(request.POST)
if not form.is_valid():
e = ','.join([form.errors[i][0] for i in form.errors]) if len(form.errors) > 0 else u'未知错误'
return HttpResponseBadRequest(json.dumps({'code': 'false', 'msg': e, 'data': []}),
content_type='application/json')
q = Auth(QINIU['access_key'], QINIU['secret_key'])
file_name = form.cleaned_data['name']
staff_id = form.cleaned_data['staff']
remark = form.cleaned_data['remark']
data_file = form.cleaned_data['data'] # reuqest.FILES.get('data')
if not models.Staff.objects.filter(id=staff_id).exists():
return HttpResponseBadRequest(json.dumps({'code': 'false', 'msg': '上传文件的员工不存在', 'data': []}),
content_type='application/json')
key = ''.join(random.sample(string.ascii_letters + string.digits, 8)) # 随机八位字符
while models.File.objects.filter(qiniu_name=key): # 假如随机的八位字符已经被使用
key = ''.join(random.sample(string.ascii_letters + string.digits, 8)) # 新随机八位字符
token = q.upload_token(QINIU['bucket_name'], key, 3600)
base64_file = base64.b64encode(data_file.read())
qiniu_upload_url = "http://up-z2.qiniu.com/putb64/%s/key/%s/mimeType/%s" % \
(str(-1), urlsafe_base64_encode(key), urlsafe_base64_encode(file_name.split('.')[-1]))
headers = {"Content-type": "application/octet-stream", "Authorization": "UpToken " + token}
requests.post(qiniu_upload_url, headers=headers, data=base64_file)
# resp = json.loads(requests.post(qiniu_upload_url, headers=headers, data=base64_file).content)
# hash = resp['hash'] # hash校验
# filename = resp['key']
file_obj = models.File()
file_obj.name = file_name
file_obj.staff = models.Staff.objects.get(id=staff_id)
file_obj.qiniu_name = key
file_obj.remark = remark
file_obj.save()
return HttpResponse(json.dumps({'code': 'ok', 'msg': '上传文档成功', 'data': []}), content_type='application/json') # 查看某员工所有自命名文档
def staff_all_file(request):
form = forms.StaffAllfile(request.POST)
if not form.is_valid():
e = ','.join([form.errors[i][0] for i in form.errors]) if len(form.errors) > 0 else u'未知错误'
return HttpResponseBadRequest(json.dumps({'code': 'false', 'msg': e, 'data': []}),
content_type='application/json')
staff_id = form.cleaned_data['id']
if not models.Staff.objects.filter(id=staff_id).exists():
return HttpResponseBadRequest(json.dumps({'code': 'false', 'msg': '员工不存在', 'data': []}),
content_type='application/json')
query_set = models.File.objects.get(id=staff_id).file.all()
data_list = list()
for i in query_set:
one_file_dic = dict()
one_file_dic['name'] = i.name
one_file_dic['qiniu_name'] = i.qiniu_name
one_file_dic['remark'] = i.remark
data_list.append(one_file_dic)
json_dic = {'code': 'ok', 'data': data_list, 'msg': '查询员工所有文档成功'}
return HttpResponse(json.dumps(json_dic), content_type='application/json') def download_staff_file(request):
form = forms.DownloadStafffile(request.POST)
if not form.is_valid():
e = ','.join([form.errors[i][0] for i in form.errors]) if len(form.errors) > 0 else u'未知错误'
return HttpResponseBadRequest(json.dumps({'code': 'false', 'msg': e, 'data': []}),
content_type='application/json')
q = Auth(QINIU['access_key'], QINIU['secret_key'])
qiniu_name = form.cleaned_data['qiniu_name']
url = 'http://pn9re4v61.bkt.clouddn.com/{}?attname='.format(qiniu_name)
private_url = q.private_download_url(url, expires=300)
return redirect(private_url)

Django+七牛上传+查看+下载文件相关函数,新整理未完全测试的更多相关文章

  1. iOS 客户端获取七牛上传token

    一.官方参考文档: 1.上传策略http://developer.qiniu.com/article/developer/security/put-policy.html 2.上传凭证(即uptoke ...

  2. 每天一个linux命令(26):用SecureCRT来上传和下载文件

    用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...

  3. 利用SecureCRT上传、下载文件(使用sz与rz命令),超实用!

    利用SecureCRT上传.下载文件(使用sz与rz命令),超实用! 文章来源:http://blog.csdn.net/dongqinliuzi/article/details/39623169 借 ...

  4. 每天一个linux命令(26)--用SecureCRT来上传和下载文件

    用SSH管理Linux 服务器时经常需要远程与本地之间交互文件,而直接使用 SecureCRT 自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmod ...

  5. 每天一个linux命令(26):用SecureCRT来上传和下载文件(转载自竹子)

    用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...

  6. 用SecureCRT来上传和下载文件

    用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...

  7. Linux学习笔记:使用ftp命令上传和下载文件

    Linux中如何使用ftp命令,包括如何连接ftp服务器,上传or下载文件以及创建文件夹.虽然现在有很多ftp桌面应用(例如:FlashFXP),但是在服务器.SSH.远程会话中掌握命令行ftp的使用 ...

  8. linux常用命令:用SecureCRT来上传和下载文件

    用SSH管理linux服务器时经常需要远程与本地之间交互文件.而直接用SecureCRT自带的上传下载功能无疑是最方便的,SecureCRT下的文件传输协议有ASCII.Xmodem.Zmodem. ...

  9. oracle EBS上传和下载文件(转)

    最近一直在做一个工作流的项目,最终用户要求在发送消息的时候可以附带附件,这个又是给我的一个难题.在网上查了一下ORACLE上传资料,找到了黄建华前辈写的<Oracle EBS Forms开发指南 ...

随机推荐

  1. 磁盘IO性能监控(Linux 和 Windows)

    磁盘IO性能监控(Linux 和 Windows) 作者:终南   <li.zhongnan@hotmail.com> 磁盘的IO性能是衡量计算机总体性能的一个重要指标.Linux提供了i ...

  2. endnote X7使用方法

    网页版的endnote不能添加新模版,只能用模版库里的那些,所以转而试试离线版客户端. 1.下载安装完以后(下载地址就不给了,网上有很多),在word里可以看到顶栏有插件,如果你同时也安装了在线版本, ...

  3. ansible学习(二)

    什么是YAML? YAML是一种标记语言.适合用来表达层次结构式的数据结构. YAML的基本组件:清单(短杠——空白字符)和散列表(短杠+空白字符分隔key:value对). Playbook的核心元 ...

  4. n阶楼梯,一次走1&comma;2&comma;3步,求多少种不同走法

    ##已知n阶楼梯,一次可以迈1,2,3步.求所有走法## 如果要列出走法,时间复杂度太高,O(n)=2**n,前两个函数遍历走法.## 如果只是单纯列出走法数量,就简单多了,也但是很容易内存爆表. # ...

  5. rosetta mpi编译时出现 MPI has not been declared 错误

    安装openmpi2.1.0版本,编译mpi rosetta时出现 MPI has not been declared 错误,经过一系列的摸索发现安装openmpi-1.6.5就可以顺利编译,降低版本 ...

  6. Java类型中ParameterizedType,GenericArrayType,TypeVariabl,WildcardType详解

    (1). 和反射+泛型有关的接口类型 java.lang.reflect.Type:java语言中所有类型的公共父接口 java.lang.reflect.ParameterizedType java ...

  7. asp&period;net mvc 笔记一

    webapi controller 中 action 名称 不能与 View controller  中的 action 名称相同,否则 Url.Action("actionName&quo ...

  8. ISO7816之管脚定义

    卡座的管脚定义 如果使用示波器或者逻辑分析仪来观察 连接C3.C5.C7 小技巧当C3为3.57MHZ时候,可以使用波特率为9600的串口来监听.

  9. 强化学习算法Policy Gradient

    1 算法的优缺点 1.1 优点 在DQN算法中,神经网络输出的是动作的q值,这对于一个agent拥有少数的离散的动作还是可以的.但是如果某个agent的动作是连续的,这无疑对DQN算法是一个巨大的挑战 ...

  10. java读书笔记二

    这是我的一些读书笔记: 我研究了一下面向对象: 面向对象符合人类看待事物的一般规律,对象的方法的实现细节是包装的,只有对象方法的实现者了解细节 我觉得面向过程是由过程.步骤.函数组成,过程是核心,面向 ...