洞察纵观鸿蒙next版本,如何凭借FinClip加强小程序的跨平台管理,确保企业在数字化转型中的高效运营和数据安全?
630
2022-09-10
52. Django 2.1.7 使用go-fastdfs上传文件
上一篇文章go-fastdfs安装以及python调用讲解了关于go-fastdfs这个开源的分布式文件存储系统的安装以及python上传文件的方式。
本篇章来讲解继承到Django2.1.7来进行使用。
go-fastdfs关于python上传文件的示例代码
import requestsurl = '= {'file': open('report.xls', 'rb')}options={'output':'json','path':'','scene':''} #参阅浏览器上传的选项r = requests.post(url,data=options, files=files)print(r.text)
对于这个示例代码,上一篇在安装的时候,也进行了测试,也是成功上传的。下面来看看怎么在Django写一个从html的form表单上传一个单一文件,然后Django后台将文件上传到go-fastdfs的流程。
上传流程时序图
在本次示例中,不启动Go-FastDFS的认证auth_url等等功能,不使用web直接上传的方式。先以默认Go-FastDFS配置进行上传示例编写。
编写Django集成使用go-fastdfs示例
1) 首先编写一个上传文件的html页面file_upload_fastdfs.html
2) 在应用的views.py编写视图显示上传页面
def fastdfs_upload_test(request): return render(request, 'assetinfo/file_upload_fastdfs.html')
3) 在应用的urls.py编写请求的url路径
urlpatterns = [ # ex:/assetinfo/fastdfs_upload_test path('fastdfs_upload_test', views.fastdfs_upload_test, name='fastdfs_upload_test'),]
4) 查看上传页面显示 访问:在应用的views.py编写处理上传文件业务的方法
def fasetdfs_file_upload_handle(request): """接收上传文件,并上传至Go-FastDFS文件存储服务中""" file = request.FILES.get('file') # 设置保存路径 temp_file = '%s/assetinfo/%s' % (settings.MEDIA_ROOT, file.name) # 将文件写入临时文件 with open(temp_file, 'wb') as upload_file: for c in file.chunks(): upload_file.write(c) # 使用go-fast import requests url = '# 上传go-fast options = {'output': 'json', 'path': '', 'scene': ''} with open(temp_file,'rb') as file: # 以临时文件path的方式上传 r = requests.post(url, data=options, files={'file':file}) # print(r.text) # 解析go-fast import json res_json = json.loads(r.text) # 将go-fastdfs返回的结果转为json # 根据返回的结果,另外将其存储至数据库之中,这里不做数据存储处理。 print("url = %s" % res_json['url']) print("path = %s" % res_json['path']) print("domain = %s" % res_json['domain']) print("md5 = %s" % res_json['md5']) # 删除保存在本地路径的文件 os.remove(path) import os if os.path.exists(temp_file): # 删除临时文件 os.remove(temp_file) from django.import JsonResponse return JsonResponse({"code": 0})
6)在应用的urls.py配置url
urlpatterns = [ # ex:/assetinfo/fasetdfs_file_upload_handle path('fasetdfs_file_upload_handle', views.fasetdfs_file_upload_handle, name='fasetdfs_file_upload_handle'),]
7) 测试上传文件
8) 查看django后台打印的信息,确认上传结果
url = = /group1/default/20190820/13/58/2/头像.jpgdomain = = cf38f0ac32ac608fb87c9bb18fced981[20/Aug/2019 13:58:44] "POST /assetinfo/fasetdfs_file_upload_handle HTTP/1.1" 200 11
信息正确,功能完成。
9)最后简单写一个html视图,来显示刚刚上传的图片url
在浏览器访问如下:
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~