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. How to enable Linux-PAM on uClinux

    By default the uClinux  uses the tools provided by busybox firstly. So the init login and passwd are ...

  2. InnoDB中锁的查看

    Ⅰ. show engine innodb status\G 1.1 实力分析一波 锁介绍的那篇中已经提到了这个命令,现在我们开一个参数,更细致的分析一下这个命令 (root@localhost) [ ...

  3. Cookie:解决HTTP协议无保存状态

    客户端 Cookie会根据从服务器端发送的相应报文内一个叫Set-Cookie的首部字段信息,通知客户端保存Cookie.当下次客户端再往该服务器发送请求时,客户端会自动在请求报文中加入Cookie值 ...

  4. Spark入门到精通--(第二节)Scala编程详解基础语法

    Scala是什么? Scala是以实现scaleable language为初衷设计出来的一门语言.官方中,称它是object-oriented language和functional languag ...

  5. 【UML】NO.46.EBook.5.UML.1.006-【UML 大战需求分析】- 用例图(Use Case Diagram)

    1.0.0 Summary Tittle:[UML]NO.46.EBook.1.UML.1.006-[UML 大战需求分析]- 用例图(Use Case Diagram) Style:DesignPa ...

  6. solr6.5.1搜索引擎的部署

    目录结构如下: 6.5.1版本的solr已经集成有jetty服务器(在server目录下),所以可以直接启动solr应用. 1.java环境配置好(这里不再累赘). 2.打开cmd,路径切换到bin目 ...

  7. python头部 #!/usr/bin/env python

    *.py运行: python *.py OR ./*.py 对于*.py其首行应标明 #!/usr/bin/env python,定义python解释器调用路径,对比#!/usr/bin/python ...

  8. JavaWeb-----ServletConfig对象和servletContext对象

    1.ServletConfig ServletConfig:代表当前Servlet在web.xml中的配置信息 String getServletName()  -- 获取当前Servlet在web. ...

  9. Nginx技术研究系列5-动态路由升级版

    前几篇文章我们介绍了Nginx的配置.OpenResty安装配置.基于Redis的动态路由以及Nginx的监控. Nginx-OpenResty安装配置 Nginx配置详解 Nginx技术研究系列1- ...

  10. UI自动化(八)xpath

    由于最新版火狐不在支持FireBug等开发工具,可以通过https://ftp.mozilla.org/pub/firefox/releases/下载49版本以下的火狐就可以增加Firebug等扩展了 ...