Python+Django度假村旅游景点景区酒店预订系统

文末获取资源,收藏关注不迷路

一、Python+Django度假村管理系统项目介绍

项目编号7t82p
实现了一个完整的农家乐系统,其中主要有用户表模块、关于我们模块、收藏表模块、公告信息模块、酒店预订模块、酒店信息模块、景区信息模块、景区订票模块、景点分类模块、会员等级模块、会员模块、交流论坛模块、度假村信息模块、配置文件模块、在线客服模块、关于我们模块、账户的注册与登录等功能模块。本文详细介绍了该农家乐系统的设计过程,并通过全面测试,完善了预期的功能

二、Python+Django度假村管理系统主要使用技术

环境需要
1.运行环境:python3.7/python3.8。
2.IDE环境:pycharm+mysql5.7;
3.数据库工具:Navicat11
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.数据库:MySql 5.7版本;
技术栈
后端:python+django
前端:vue+CSS+JavaScript+jQuery+elementui

使用说明
使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
使用PyCharm 导入项目,修改配置,运行项目;
将项目中config.ini配置文件中的数据库配置改为自己的配置,然后运行;
运行成功后,在浏览器中输入:http://localhost:8080/项目名

三、Python+Django度假村管理系统研究内容

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
本系统的设计与实现共包含16个表:分别是关于我们信息表,在线客服信息表,配置文件信息表,度假村信息信息表,交流论坛信息表,会员信息表,会员等级信息表,景点分类信息表,景区订票信息表,景区信息信息表,酒店信息信息表,酒店预订信息表,公告信息信息表,收藏表信息表,关于我们信息表,用户表信息表,

关于我们 (自动编号、图片3、图片2、内容、创建时间、副标题、图片1、标题);
在线客服 (自动编号、是否回复、用户id、管理员id、提问、回复、创建时间);
配置文件 (自动编号、配置参数值、配置参数名称);
度假村信息 (自动编号、最近点击时间、度假村图片、度假村名称、创建时间、度假村地址、点击次数、创建时间、度假村简介、度假村等级);
交流论坛 (自动编号、帖子标题、父节点id、用户id、用户名、头像、创建时间、状态、帖子内容);
会员 (自动编号、会员姓名、会员账号、折扣、会员电话、头像、性别、创建时间、等级、密码);
会员等级 (自动编号、等级、创建时间、折扣);
景点分类 (自动编号、创建时间、景点分类);
景区订票 (自动编号、创建时间、总价格、度假村名称、订票时间、是否支付、会员账号、景点分类、折扣、订票备注、订票编号、会员电话、会员姓名、景点名称、等级、订票数量、门票价格);
景区信息 (自动编号、发布时间、景点等级、点击次数、度假村名称、门票价格、景点名称、景点封面、创建时间、景点地址、景点分类、最近点击时间、景点编号、景点介绍);
酒店信息 (自动编号、房间类型、酒店介绍、点击次数、酒店名称、酒店地址、星级、酒店图片、最近点击时间、发布时间、创建时间、类别、价格、度假村名称);
酒店预订 (自动编号、等级、价格、会员账号、折扣、预订天数、房间类型、是否支付、预订时间、总价格、预订编号、酒店名称、会员电话、度假村名称、会员姓名、预订备注、创建时间);
公告信息 (自动编号、内容、简介、创建时间、标题、图片);
收藏表 (自动编号、类型(1:收藏,21:赞,22:踩,31:竞拍参与,41:关注)、备注、名称、推荐类型、表名、创建时间、用户id、商品id、图片);
关于我们 (自动编号、内容、图片2、标题、图片1、副标题、图片3、创建时间);
用户表 (自动编号、用户名、密码、角色、新增时间);
在这里插入图片描述
在这里插入图片描述

四、核心代码

# coding:utf-8
__author__ = "ila"

from django.http import JsonResponse

from .users_model import users
from util.codes import *
from util.auth import Auth
import util.message as mes


def users_login(request):
    if request.method in ["POST", "GET"]:
        msg = {
    
    'code': normal_code, "msg": mes.normal_code}
        req_dict = request.session.get("req_dict")
        if req_dict.get('role')!=None:
            del req_dict['role']
        datas = users.getbyparams(users, users, req_dict)
        if not datas:
            msg['code'] = password_error_code
            msg['msg'] = mes.password_error_code
            return JsonResponse(msg)

        req_dict['id'] = datas[0].get('id')
        return Auth.authenticate(Auth, users, req_dict)


def users_register(request):
    if request.method in ["POST", "GET"]:
        msg = {
    
    'code': normal_code, "msg": mes.normal_code}
        req_dict = request.session.get("req_dict")

        error = users.createbyreq(users, users, req_dict)
        if error != None:
            msg['code'] = crud_error_code
            msg['msg'] = error
        return JsonResponse(msg)


def users_session(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code,"msg":mes.normal_code, "data": {
    
    }}

        req_dict = {
    
    "id": request.session.get('params').get("id")}
        msg['data'] = users.getbyparams(users, users, req_dict)[0]

        return JsonResponse(msg)


def users_logout(request):
    if request.method in ["POST", "GET"]:
        msg = {
    
    
            "msg": "退出成功",
            "code": 0
        }

        return JsonResponse(msg)


def users_page(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code, "msg": mes.normal_code,
               "data": {
    
    "currPage": 1, "totalPage": 1, "total": 1, "pageSize": 10, "list": []}}
        req_dict = request.session.get("req_dict")
        tablename = request.session.get("tablename")
        try:
            __hasMessage__ = users.__hasMessage__
        except:
            __hasMessage__ = None
        if __hasMessage__ and __hasMessage__ != "否":

            if tablename != "users":
                req_dict["userid"] = request.session.get("params").get("id")
        if tablename == "users":
            msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \
            msg['data']['pageSize'] = users.page(users, users, req_dict)
        else:
            msg['data']['list'], msg['data']['currPage'], msg['data']['totalPage'], msg['data']['total'], \
            msg['data']['pageSize'] = [],1,0,0,10

        return JsonResponse(msg)


def users_info(request, id_):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code, "msg": mes.normal_code, "data": {
    
    }}

        data = users.getbyid(users, users, int(id_))
        if len(data) > 0:
            msg['data'] = data[0]
        # 浏览点击次数
        try:
            __browseClick__ = users.__browseClick__
        except:
            __browseClick__ = None

        if __browseClick__ and "clicknum" in users.getallcolumn(users, users):
            click_dict = {
    
    "id": int(id_), "clicknum": str(int(data[0].get("clicknum", 0)) + 1)}
            ret = users.updatebyparams(users, users, click_dict)
            if ret != None:
                msg['code'] = crud_error_code
                msg['msg'] = ret
        return JsonResponse(msg)


def users_save(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code, "msg": mes.normal_code, "data": {
    
    }}
        req_dict = request.session.get("req_dict")
        req_dict['role'] = '管理员'
        error = users.createbyreq(users, users, req_dict)
        if error != None:
            msg['code'] = crud_error_code
            msg['msg'] = error
        return JsonResponse(msg)


def users_update(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code, "msg": mes.normal_code, "data": {
    
    }}
        req_dict = request.session.get("req_dict")
        if req_dict.get("mima") and req_dict.get("password"):
            if "mima" not in users.getallcolumn(users,users):
                del req_dict["mima"]
            if "password" not in users.getallcolumn(users,users):
                del req_dict["password"]
        try:
            del req_dict["clicknum"]
        except:
            pass
        error = users.updatebyparams(users, users, req_dict)
        if error != None:
            msg['code'] = crud_error_code
            msg['msg'] = error
        return JsonResponse(msg)


def users_delete(request):
    '''
    '''
    if request.method in ["POST", "GET"]:
        msg = {
    
    "code": normal_code, "msg": mes.normal_code, "data": {
    
    }}
        req_dict = request.session.get("req_dict")

        error = users.deletes(users,
            users,
            req_dict.get("ids")
        )
        if error != None:
            msg['code'] = crud_error_code
            msg['msg'] = error
        return JsonResponse(msg)

五、文章目录

1系统概述 1
1.1 研究背景 1
1.2研究目的 1
1.3系统设计思想 1
2相关技术 3
2.1 MYSQL数据库 3
2.2 B/S结构 3
2.3 Djangot框架简介 4
2.4 VUE框架 4
3系统分析 5
3.1可行性分析 5
3.1.1技术可行性 5
3.1.2经济可行性 5
3.1.3操作可行性 5
3.2系统性能分析 6
3.2.1 系统安全性 6
3.2.2 数据完整性 6
3.3系统界面分析 6
3.4系统流程和逻辑 8
4系统概要设计 9
4.1概述 9
4.2系统结构 10
4.3.数据库设计 11
4.3.1数据库实体 11
4.3.2数据库设计表 13
5系统详细实现 17
5.1 管理员模块的实现 17
5.2用户模块的实现 19
6系统测试 21
6.1概念和意义 21
6.2特性 22
6.3重要性 22
6.4测试方法 23
6.5 功能测试 23
6.6可用性测试 24
6.7性能测试 24
6.8测试分析 24
6.9测试结果分析 25
结论 25
致谢语 26
参考文献 26

猜你喜欢

转载自blog.csdn.net/z459382737/article/details/143194811