前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django 2.1.7 使用go-fastdfs上传文件

Django 2.1.7 使用go-fastdfs上传文件

作者头像
Devops海洋的渔夫
发布2019-08-21 17:56:00
1.4K0
发布2019-08-21 17:56:00
举报
文章被收录于专栏:Devops专栏Devops专栏

上一篇文章go-fastdfs安装以及python调用讲解了关于go-fastdfs这个开源的分布式文件存储系统的安装以及python上传文件的方式。

本篇章来讲解继承到Django2.1.7来进行使用。

go-fastdfs关于python上传文件的示例代码

代码语言:javascript
复制
import requests
url = 'http://10.1.5.9:8080/upload'
files = {'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

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>上传文件</title>
</head>
<body>
    <form method="post" action="{% url 'assetinfo:fasetdfs_file_upload_handle' %}" enctype="multipart/form-data">
        {%csrf_token%}
        <input type="file" name="file"/><br>
        <input type="submit" value="上传">
    </form>
</body>
</html>

2) 在应用的views.py编写视图显示上传页面

代码语言:javascript
复制
def fastdfs_upload_test(request):
    return render(request, 'assetinfo/file_upload_fastdfs.html')

3) 在应用的urls.py编写请求的url路径

代码语言:javascript
复制
urlpatterns = [
    # ex:/assetinfo/fastdfs_upload_test
    path('fastdfs_upload_test', views.fastdfs_upload_test, name='fastdfs_upload_test'),
]

4) 查看上传页面显示

访问: http://127.0.0.1:8000/assetinfo/fastdfs_upload_test

好了,到这里已经完成了页面上传文件的部分,下面继续写Django接收请求,并上传文件至Go-FastDFS的功能。

5) 在应用的views.py编写处理上传文件业务的方法

代码语言:javascript
复制
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-fasthttp上传文件
    import requests
    url = 'http://127.0.0.1:8080/upload' # 上传go-fasthttp的url路径
    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-fasthttp返回的上传结果
    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.http.response import JsonResponse
    return JsonResponse({"code": 0})

6)在应用的urls.py配置url

代码语言:javascript
复制
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后台打印的信息,确认上传结果

代码语言:javascript
复制
url = http://127.0.0.1:8080/group1/default/20190820/13/58/2/头像.jpg
path = /group1/default/20190820/13/58/2/头像.jpg
domain = http://127.0.0.1:8080
md5 = cf38f0ac32ac608fb87c9bb18fced981
[20/Aug/2019 13:58:44] "POST /assetinfo/fasetdfs_file_upload_handle HTTP/1.1" 200 11

信息正确,功能完成。

9)最后简单写一个html视图,来显示刚刚上传的图片url

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>显示图片</title>
</head>
<body>
    <img src="http://127.0.0.1:8080/group1/default/20190820/13/58/2/头像.jpg">
</body>
</html>

在浏览器访问如下:

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019.08.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • go-fastdfs关于python上传文件的示例代码
  • 上传流程时序图
  • 编写Django集成使用go-fastdfs示例
相关产品与服务
文件存储
文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档