Django之云存储(二)

59 篇文章 ¥19.90 ¥99.00

一、Django使用云存储

image-20221208174630435

  • 建立项目

    django-admin startproject  project_demo
    
  • 创建子应用

    python manage.py startapp app_name
    
  • 修改配置文件,设置模板视图路径

    settings.py

    TEMPLATES = [
       {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [os.path.join(BASE_DIR,'templates')],
        'APP_DIRS': True,
        'OPTIONS': {
          'context_processors': [
            'django.template.context_processors.debug',
            'django.template.context_processors.request',
            'django.contrib.auth.context_processors.auth',
            'django.contrib.messages.context_processors.messages',
           ],
         },
       },
    ]
    
  • 建立逻辑视图

    from django.shortcuts import render
    
    
    from .models import Upload
    # Create your views here.
    def upload_file(request):
      if request.method == 'GET':
        return render(request,'upload.html')
      # 上传文件
      elif request.method == 'POST':
        # 获取上传的文件,如果没有文件,则默认为None
        file = request.FILES.get('file')
            
      return render(request,'show.html',{'upload':upload})
    
    
    def get_file(request,pk):
      # 获取文件
      upload = Upload.objects.get(pk=pk)
      return render(request,'show.html',{'upload':upload})
    
  • 建立路由地址

    from django.urls import path
    
    
    from . import views
    
    
    urlpatterns = [
      path('upload_file/', views.upload_file, name='upload_file'),
      path('get_file/<int:pk>/', views.get_file, name='get_file'),
    ]
    
  • 建立模板页面

    upload.html

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <meta http-equiv="X-UA-Compatible" content="IE=edge">
      <meta name="viewport" content="width=device-width, initial-scale=1.0">
      <title>Document</title>
    </head>
    <body>
      <h2>这个测试</h2>
      <form action="/upload_file/" method="post" enctype="multipart/form-data">
         {% csrf_token %}
        <input type="file" name="img"><br>
        <input type="text" name="desc"><br>
        <input type="submit" value="上传">
      </form>
      
    </body>
    </html>
    

        show.html

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <ul>
    <li>图片名:{{img.name}}</li>
    <li>图片地址:{{img.url}}</li>
    <li><img src="{{img.url}}" alt=""></li>
  </ul>
</body>
</html>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜鸟之编程

您的支持将成为我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值