tsx81428 发表于 7 天前

一个基于Django的写字楼管理系统实现方案

一个基于Django的写字楼管理系统实现方案

用户现在必要我用Django来编写一个写字楼管理系统的Web版本,要求包罗增编削查写字楼的HTML页面,视频管理功能,本地化部署,以及职员权限管理,包含完整的代码结构和功能实现:
1. 项目结构

首先,用户之前问过用Python的Flask和Spring Boot实现雷同系统,现在转向Django。这意味着我要提供一个完整的Django项目结构,包含模子、视图、模板以及权限管理。用户还特别提到了视频管理和权限管理,这两个是新增的功能点,必要特别注意。
bash
复制
office_management/
├── office/
│   ├── migrations/
│   ├── templates/
│   │   ├── buildings/
│   │   │   ├── list.html
│   │   │   ├── detail.html
│   │   │   ├── form.html
│   │   ├── videos/
│   │   │   ├── video_list.html
│   │   ├── registration/
│   │   │   ├── login.html
│   │   │   ├── register.html
│   ├── models.py
│   ├── views.py
│   ├── admin.py
│   ├── urls.py
├── config/
│   ├── settings.py
│   ├── urls.py
├── media/
│   ├── videos/
├── static/
├── manage.py 2. 数据库模子 (models.py)

models.py代码,定义了简朴三哥权限,管理员,普通员工和租户
数据库方面,用户之前使用过SQLite和MySQL,Django默认使用SQLite,但也可以设置为使用其他数据库。考虑到本地化部署,可能继续使用SQLite简化设置,但用户如果有MySQL的需求,也必要在settings.py中设置。


from django.db import models
from django.contrib.auth.models import AbstractUser

class CustomUser(AbstractUser):
    ROLES = (
      ('admin', '管理员'),
      ('staff', '普通员工'),
      ('tenant', '租户')
    )
    role = models.CharField(max_length=10, choices=ROLES, default='staff')
    phone = models.CharField(max_length=20, blank=True)

class Building(models.Model):
    name = models.CharField(max_length=100)
    address = models.TextField()
    floors = models.PositiveIntegerField()
    area = models.DecimalField(max_digits=10, decimal_places=2)
    manager = models.ForeignKey(CustomUser, on_delete=models.SET_NULL, null=True)
    created_at = models.DateTimeField(auto_now_add=True)

class BuildingVideo(models.Model):
    building = models.ForeignKey(Building, on_delete=models.CASCADE)
    title = models.CharField(max_length=200)
    video_file = models.FileField(upload_to='videos/')
    description = models.TextField(blank=True)
    upload_date = models.DateTimeField(auto_now_add=True) 3. 视图逻辑 (views.py)

写字楼的list列表,
接下来是增编削查功能。Django的通用视图(Generic Views)如ListView、CreateView、UpdateView、DeleteView可以快速实现这些功能。必要创建相应的模板,比如building_list.html、building_form.html等,并在视图中处理表单提交。

from django.contrib.auth.decorators import login_required, permission_required
from django.views.generic import ListView, CreateView, UpdateView, DeleteView
from django.urls import reverse_lazy
from .models import Building, BuildingVideo

class BuildingListView(ListView):
    model = Building
    template_name = 'buildings/list.html'
    context_object_name = 'buildings'

    def get_queryset(self):
      if self.request.user.role == 'tenant':
            return Building.objects.filter(manager=self.request.user)
      return super().get_queryset()

@permission_required('office.add_building')
class BuildingCreateView(CreateView):
    model = Building
    fields = ['name', 'address', 'floors', 'area', 'manager']
    template_name = 'buildings/form.html'
    success_url = reverse_lazy('building-list')

class VideoListView(ListView):
    model = BuildingVideo
    template_name = 'videos/video_list.html'

    def get_queryset(self):
      return BuildingVideo.objects.filter(building_id=self.kwargs['pk']) 4. 模板示例 (list.html)

可以通过浏览器的list.html
{% extends "base.html" %}
{% block content %}
<h2>写字楼管理</h2>
{% if perms.office.add_building %}
<a href="{% url 'building-create' %}" class="btn btn-primary mb-3">新增楼宇</a>
{% endif %}

<table class="table table-hover">
    <thead>
      <tr>
            <th>名称</th>
            <th>地址</th>
            <th>楼层</th>
            <th>面积</th>
            <th>操作</th>
      </tr>
    </thead>
    <tbody>
      {% for building in buildings %}
      <tr>
            <td>{{ building.name }}</td>
            <td>{{ building.address }}</td>
            <td>{{ building.floors }}</td>
            <td>{{ building.area }}㎡</td>
            <td>
                <a href="{% url 'building-detail' building.id %}" class="btn btn-info btn-sm">详情</a>
                {% if perms.office.change_building %}
                <a href="{% url 'building-update' building.id %}" class="btn btn-warning btn-sm">编辑</a>
                {% endif %}
            </td>
      </tr>
      {% endfor %}
    </tbody>
</table>
{% endblock %} 运行 HTML
5. 权限设置 (settings.py)

权限管理方面,Django内置了用户认证系统,可以在此底子上扩展。用户可能必要不同角色,比如管理员和普通用户,管理员可以管理写字楼信息,普通用户只能查看。可能必要使用Django的组(Groups)和权限(Permissions),大概自定义用户模子来添加角色字段。

设置url的权限设置
AUTH_USER_MODEL = 'office.CustomUser'

LOGIN_URL = '/login/'
LOGIN_REDIRECT_URL = '/buildings/'
LOGOUT_REDIRECT_URL = '/'

MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, 'media/') 6. URL路由设置 (urls.py)

url定义路由
from django.urls import path
from office import views

urlpatterns = [
    path('buildings/', views.BuildingListView.as_view(), name='building-list'),
    path('building/create/', views.BuildingCreateView.as_view(), name='building-create'),
    path('building/<int:pk>/videos/', views.VideoListView.as_view(), name='building-videos'),
   
    # 视频管理
    path('video/upload/', views.VideoUploadView.as_view(), name='video-upload'),
    path('video/<int:pk>/delete/', views.VideoDeleteView.as_view(), name='video-delete'),
   
    # 用户认证
    path('accounts/', include('django.contrib.auth.urls')),
    path('register/', views.RegisterView.as_view(), name='register'),
] 7. 视频管理功能

视频管理部门必要单独的模子,可能包罗标题、形貌、视频文件、上传时间、关联的写字楼等字段。在模板中,必要上传视频的表单,并在详情页显示视频列表,可能还必要播放视频的功能,可以使用HTML5的video标签。
视频管理部门,我必要考虑怎样存储视频文件。Django通常使用FileField和ImageField来处理文件上传,但视频文件较大,可能必要设置MEDIA_ROOT和MEDIA_URL,同时考虑使用Django的静态文件服务大概更好的生产环境方案,比如Nginx来处理静态文件。不外用户提到本地化部署,可能临时不必要考虑生产环境,所以先用Django的开辟服务器处理上传文件。
# views.py
class VideoUploadView(LoginRequiredMixin, CreateView):
    model = BuildingVideo
    fields = ['building', 'title', 'video_file', 'description']
    template_name = 'videos/upload.html'
   
    def form_valid(self, form):
      form.instance.uploader = self.request.user
      return super().form_valid(form)

class VideoDeleteView(PermissionRequiredMixin, DeleteView):
    model = BuildingVideo
    permission_required = 'office.delete_buildingvideo'
    success_url = reverse_lazy('building-list') 8. 权限管理装饰器示例

权限管理必要装饰器,比如@login_required和@permission_required,来控制访问权限。用户注册和登录可以使用Django自带的auth模块,大概自定义用户模子。可能必要创建用户组,分配不同的权限,比如管理员组有增编削查的权限,普通用户只有查看权限。

python

复制

# 在视图中使用
@method_decorator(permission_required('office.add_building'), name='dispatch')
class BuildingCreateView(CreateView):
    ...

# 在模板中检查权限
{% if perms.office.delete_building %}
<button class="btn btn-danger">删除</button>
{% endif %} 9. 运行部署步调

必要确保代码示例精确,包罗模子定义、视图函数、模板中的表单和权限判定,以及URL设置。同时,给出运行步调,安装依赖,迁移数据库,创建超级用户等。

  1)安装依赖

        pip install django pillow
  2)数据库迁移

python manage.py makemigrations
python manage.py migrate
  3)创建管理员

 python manage.py createsuperuser
输入用户admin,email地址为admin@admin.com
输入密码为admin123 ,确定后就可以进入后台
 4)运行开辟服务器

本地化部署方面,必要确保settings.py中的ALLOWED_HOSTS设置,DEBUG模式关闭,静态文件收集等。但用户可能只是必要在本地运行,所以临时不必要处理这些生产设置,但必要给出运行步调,比如python manage.py runserver。
 python manage.py runserver
5)访问系统


http://localhost:8000/buildings/ 10. 功能扩展建议

1)视频播放页面

video.html
<video width="640" controls>
    <source src="{{ video.video_file.url }}" type="video/mp4">
    您的浏览器不支持视频播放
</video> 运行 HTML
2)高级权限控制

# 自定义权限类
class IsBuildingManager(permissions.BasePermission):
    def has_object_permission(self, request, view, obj):
      return obj.manager == request.user 1)本地化设置


# settings.py
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
USE_I18N = True
USE_L10N = True 2)文件上传限定

# 在forms.py中添加验证
class VideoUploadForm(forms.ModelForm):
    class Meta:
      model = BuildingVideo
      fields = '__all__'
   
    def clean_video_file(self):
      file = self.cleaned_data['video_file']
      if file.size > 1024*1024*500:# 500MB限制
            raise ValidationError("视频文件大小不能超过500MB")
      return file 总结

这个实现方案包含以下核心功能:

[*] 完整的RBAC权限管理系统
[*] 楼宇信息CRUD操作
[*] 视频文件上传和管理
[*] 用户角色区分(管理员/员工/租户)
[*] 本地化中文支持
[*] 响应式Bootstrap界面
[*] 文件上传和媒体管理
[*] Django Admin后台管理
可根据实际需求通过以下方式扩展:


[*] 添加合同管理模块
[*] 集成报表生乐成能
[*] 添加消息通知系统
[*] 实现API接口
[*] 集成第三方存储(如阿里云OSS)
[*] 添加工作流审批功能

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 一个基于Django的写字楼管理系统实现方案