django通过admin实现ImageField图片上传数据库并显示

1、完成用户信息注册操作
2、将用户信息入库
3、将上传文件存放至项目下media文件夹下
4、显示所有用户信息

创建模型类

class Person(models.Model):
‘’‘人员表’’’

gender = (
    ('male','男'),
    ('female','女'),
)

姓名 = models.CharField(max_length=128,unique=True)
性别 = models.CharField(max_length=32,choices=gender,default='男')
职位 = models.CharField(max_length=256)
照片 = models.ImageField(blank=True,upload_to='photo')
邮箱 = models.EmailField(unique=True)
个人简介 = models.CharField(max_length=256,blank=True)
c_time = models.DateTimeField(auto_now_add=True)

settings.py文件中文件上传相关设置

INSTALLED_APPS = [
‘django.contrib.admin’,
‘django.contrib.auth’,
‘django.contrib.contenttypes’,
‘django.contrib.sessions’,
‘django.contrib.messages’,
‘django.contrib.staticfiles’,
‘fxperson’,
]

DATABASES = {
‘default’: {
#‘ENGINE’: ‘django.db.backends.sqlite3’,
‘ENGINE’: ‘django.db.backends.mysql’,
#‘NAME’: os.path.join(BASE_DIR, ‘db.sqlite3’),
‘NAME’: ‘django’,
‘USER’:‘root’,
‘PASSWORD’:‘fuxin#2345’,
‘HOST’:‘127.0.0.1’,
‘PORT’:‘3306’,
}
}

MEDIA_URL = ‘/media/’
MEDIA_ROOT = os.path.join(BASE_DIR,‘media’)

映射数据库表

#在终端中敲命令
python manage.py makemigrations test
python manage.py migrate

配置URL

from django.contrib import admin
from fxperson import personviews
from django.urls import path,re_path,include
from fuxin.settings import MEDIA_ROOT
from django.views.static import serve

urlpatterns = [
re_path(r’^media/(?P .*)/$’, serve, {“document_root”: MEDIA_ROOT}),
url(r’^admin/’, admin.site.urls),
url(r’^person/’, personviews.person),
]

创建视图

from django.shortcuts import render,redirect
from .models import Person

def person(request):
if not request.session.get(‘is_login’, None):
return redirect("/index/")
if request.session.get(‘is_login’, None):
list_show = []
obj = Person.objects.all().values()
for i in obj:
del i[‘id’]
del i[‘c_time’]
for i in obj:
print(i)
if i[‘职位’] == ‘软件开发工程师’:
list_show.append(i)
return render(request,‘fxperson/person.html’,{‘o’:list_show})

创建模板

{% extends 'login/base.html' %}
{% block title %}人员信息{% endblock %}
{% block content %}
    {% if request.session.is_login %}
    <h6>你好,{{ request.session.user_name }}!欢迎回来!</h6>
    <div style="max-width:1000px;margin:0 auto;">
        <h4 style="margin-bottom:0;">人员信息</h4><br>
        <div id="menu" style="float:left;">
        <a href="/person/"><span style="color:#000000">管理团队</span></a><br><br>
        <a href="/person/"><span style="color:#000000">开发团队</span></a><br><br>
        <a href="/person/"><span style="color:#000000">测试团队</span></a><br><br>
        <a href="/person/"><span style="color:#000000">后勤团队</span></a><br><br>
        </div>
        <div id="content" style="float:left;font-size:14px;text-indent:28px;">
        <a href="/person/"></a>
            {% for row in o %}
                {% for key,value in row.items %}
                    {% if  key != '照片' %}
                        <p>{{ key }}:{{ value }}</p>
                    {% elif  key == '照片' and value == '' %}
                        <p>{{ key }}:{{ value }}</p>
                    {% elif  key == '照片' and value != '' %}
                        <p>{{ key }}:</p>
                        <p style="margin-bottom:20px;"><img src="/media/{{value}}" width=100 height=100></p>
                    {% endif %}
                {% endfor %}
                <br>
            {% endfor %}
        </div>
        </div>
    {% else %}
    <h6>你尚未登录,只能访问公开内容!</h6>
    {% endif %}
{% endblock %}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要在 Djangoadmin 后台中添加图片,需要进行以下步骤: 1. 在你的模型中添加一个 ImageField 字段,例如: ```python from django.db import models class MyModel(models.Model): name = models.CharField(max_length=100) image = models.ImageField(upload_to='images/') ``` 2. 在 admin.py 文件中注册你的模型,并创建一个自定义的模型表单类来处理文件上传,例如: ```python from django.contrib import admin from django.forms import ModelForm from .models import MyModel class MyModelForm(ModelForm): class Meta: model = MyModel fields = '__all__' def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) instance = getattr(self, 'instance', None) if instance and instance.id: self.fields['image'].required = False class MyModelAdmin(admin.ModelAdmin): form = MyModelForm admin.site.register(MyModel, MyModelAdmin) ``` 3. 确保你的 MEDIA_URL 和 MEDIA_ROOT 设置正确,并且在你的 urls.py 文件中添加一个 urlpatterns 来处理 media 文件,例如: ```python from django.conf import settings from django.conf.urls.static import static from django.contrib import admin from django.urls import path urlpatterns = [ path('admin/', admin.site.urls), ] if settings.DEBUG: urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) ``` 4. 最后,在 admin 后台中创建或编辑一个 MyModel 对象时,你应该会看到一个可以上传图片的表单字段。 注意:以上代码仅供参考,你需要根据你的具体情况进行调整。 ### 回答2: 在Djangoadmin中添加图片可以通过以下步骤完成: 1. 首先,在你的models.py文件中定义一个模型类,该类包含一个FileFieldImageField字段,用于存储图片。例如: ```python from django.db import models class MyModel(models.Model): # 其他字段... image = models.ImageField(upload_to='images/') ``` 2. 在admin.py文件中注册该模型类,并用Django提供的admin.ModelAdmin类作为参数,例如: ```python from django.contrib import admin from .models import MyModel class MyModelAdmin(admin.ModelAdmin): # 自定义admin界面显示信息 list_display = ['id', 'image'] admin.site.register(MyModel, MyModelAdmin) ``` 3. 在settings.py文件中,添加MEDIA_URL和MEDIA_ROOT的配置,以指定图片上传和访问的路径。例如: ```python MEDIA_URL = '/media/' MEDIA_ROOT = os.path.join(BASE_DIR, 'media') ``` 4. 在项目的urls.py文件中,添加一个url模式以处理图片的访问请求。例如: ```python from django.conf.urls import url from django.conf import settings from django.conf.urls.static import static urlpatterns = [ # 其他url模式... ] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT) ``` 5. 运行Django开发服务器,并通过admin界面创建或编辑MyModel对象时,你将能够选择和上传图片。这些图片将保存在指定的MEDIA_ROOT目录中,并且在页面上以链接或小缩略图的形式进行显示。 希望以上步骤对你有帮助! ### 回答3: 在Djangoadmin后台中添加图片可以通过以下步骤进行操作: 1. 首先,在models.py文件中创建一个模型类,用于保存图片的相关信息,例如图片的名称、描述和图片本身等。同时,为图片字段添加一个FileFieldImageField类型的属性,用于保存上传的图片文件。例如: ```python from django.db import models class Image(models.Model): name = models.CharField(max_length=100) description = models.TextField() image = models.ImageField(upload_to='images/') ``` 2. 接下来,在admin.py文件中注册该模型类,以便在admin后台中能够对图片进行管理。例如: ```python from django.contrib import admin from .models import Image admin.site.register(Image) ``` 3. 运行`python manage.py makemigrations`和`python manage.py migrate`命令,将模型类的更改应用到数据库中。 4. 然后,在admin后台中登录,进入图片管理页面。可以看到已经添加了一个新的模型类Image。点击进入该模型页面,可以添加、编辑和删除图片信息。 5. 在添加或编辑图片信息时,会出现一个用于选择图片文件的文件选择框。点击选择文件按钮,选择本地的图片文件后,点击保存按钮即可将图片上传到服务器。 6. Django会默认将上传的图片文件保存在`MEDIA_ROOT`指定的目录下,可以通过在settings.py文件中设置`MEDIA_ROOT`来指定图片保存的路径。 7. 在模板中显示图片时,可以通过设置图片的URL,使用`{{ image.image.url }}`来获取图片的路径。可以在模板中使用该URL来显示图片,例如: ```html <img src="{{ image.image.url }}" alt="{{ image.name }}"> ``` 这样,就可以在Djangoadmin后台中添加和管理图片了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值