• 「Python-Django」django 实现将本地图片存入数据库,并能显示在web上


    1. 将图片存入数据库

    关于数据库基本操作的学习,请参见这一篇博客:https://www.cnblogs.com/leejy/p/6745186.html

    这里我默认,您已经会了基本操作,能在数据库中存图片了,然后,也会用图形界面操作数据库中的数据了

    2.这里,我先给出我的代码,能少走些弯路就少走些

    • a) 项目的urls.py
    from django.contrib import admin
    from django.urls import path
    from django.conf import settings
    from django.conf.urls.static import static
    urlpatterns = [
        path('admin/', admin.site.urls),
    ]+static(settings.MEDIA_URL,document_root=settings.MEDIA_ROOT)

    +号后面的一定要写,如果想出来结果的话!否则回报一个 404 的错误
    - b) 应用里的models.py

    from django.db import models
    
    # Create your models here.
    class Person(models.Model):
        name = models.CharField(max_length=30)
        age = models.IntegerField()
    
        def __unicode__(self):
        # 在Python3中使用 def __str__(self):
            return self.name
    
    class IMG(models.Model):
        img = models.ImageField(upload_to='img')
        name = models.CharField(max_length=20)
        def __str__(self):
        # 在Python3中使用 def __str__(self):
            return self.name   

    之后,你要会把IMG这个模式推送到数据库。

    python ./manage.py makemigrations
    python ./manage.py migrate   
    • c) 应用的views.py
    # Create your views here.
    def hello(request):
        IMG.objects.filter(name='bg')
        img = IMG.objects.all()
        return render(request, 'Welcome.html',{'img':img})

    把img这个参数传过去,传到Welcome.html
    - d) Welcome.html

    <!DOCTYPE HTML>
    <html>
    
    <head>
        <title> welcome </title>
    </head>
    <body >
            {% for i in img %}
            <img src="{{MEDIA_URL}}{{i.img}}">
            {% endfor %}
    
    </body> 
    </html>
    • e) 设置setting.py
    TEMPLATES = [
        {
            'BACKEND': 'django.template.backends.django.DjangoTemplates',
            'DIRS': [],
            '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',
                    'django.template.context_processors.media',
                ],
            },
        },
    ]
    
    MEDIA_URL = '/media/'
    MEDIA_ROOT = os.path.join(BASE_DIR, 'media')

    注意,东西都是配套使用的,如果e中的路径要变的话,a总的+号后面的也要跟着变化

    3. 在http://127.0.0.1:8000/admin/网址上面,上传你的图片

    土拍你

    --------------------- 本文来自 竦貊 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/Inuyasha_1314/article/details/80531900?utm_source=copy 

  • 相关阅读:
    8.3.ZooKeeper集群安装配置
    Shiro Demo 示例(SpringMVC-Mybatis-Shiro-redis)
    Shiro 学习
    JavaWeb项目:Shiro实现简单的权限控制(整合SSM)
    权限管理——权限模型和权限控制
    Java程序员面试题集(151-180)
    Java面试题集(136-150)
    Java面试题集(131-135)
    Java面试题集(116-135)
    Java面试题集(1-50)
  • 原文地址:https://www.cnblogs.com/wrxblog/p/9727886.html
Copyright © 2020-2023  润新知