目录
技术栈和环境说明
本系统以Python开发语言开发,MySQL为后台数据库,采用DJANGO/flask框架开发。Django框架是一种基于MVC的Web应用程序开发框架,具有功能强大、易于扩展、可重用性高等优点。
开发语言:python
框架:django/flask的都有
Python版本:python3.7.7
数据库:mysql
数据库工具:Navicat
开发软件:PyCharm
浏览器:谷歌浏览器
##项目介绍
科学技术日新月异,人们的生活都发生了翻天覆地的变化,OA管理系统当然也不例外。过去的信息管理都使用传统的方式实行,既花费了时间,又浪费了精力。在信息如此发达的今天,我们可以通过网络这个媒介,快速的查找自己想要的信息,更加全方面的了解自己的网站信息。而且人们也可以突破传统信息管理的僵硬模式,制定属于自己的个性化的管理方案。基于现代人们的需求,设计并开发了一款OA管理系统。
本篇文章使用python与MYSQL技术搭建了一个OA管理系统。首先,对用户提出的功能进行合理分析,然后搭建开发平台以及配置计算机软硬件;通过对数据流图以及系统结构的设计,创建相应的数据库;进行详细的设计,实现主要功能。最后测试网站,并分析测试结果,完善系统,得出系统使用说明书,方便日后的维护以及更新。
作为用户,本系统可以在线搜索,查看并且网站信息;也可以在线互动交流。作为系统的管理员,可以及时的更新数据,也可以随时随地的处理网站信息。便捷的操作界面以及全新的功能会让人们耳目一新。
本系统是基于B/S架构的网站系统,全方面的对系统的资讯进行实时的更新,对系统进行实时的维护。它的主要功能包括员工管理、部门管理、工资发放管理、客户信息管理、日程安排管理、车辆信息管理、文件信息管理、工资日志管理、签到信息管理、通知公告管理、我的信息等。
具体实现截图
预期达到的目标
1、学习系统开发和设计的技术相关知识和工作流程;
2、学习使用 PYCHARM 工具编辑前后台代码;
3、学习使用DJANGO/flask框架实现系统的开发;
4、掌握使用 MySQL 创建和编辑数据库的方法;
系统设计
基本理论:以软件工程方法学为指导理论,严格按照软件生命周期的问题定义、可行性研究、需求分析、总体设计、详细设计、编码和单元测试、综合测试和软件维护这8个阶段来执行。
(1)数据库设计:设计一个高效的数据库结构,包括用户信息、车辆信息、订单信息等数据表的设计,以及数据表之间的关联关系。
(2)系统架构设计:设计系统的整体架构,包括前端页面设计、后端设计、接口设计等。
(3)用户体验设计:设计用户友好的界面,提高用户体验,包括用户注册等操作的流程设计。
(4)前端页面设计:使用Python的Web框架,如Django或Flask,可以快速开发用户友好的前端页面。
前端的数据收集及可视化研究,熟悉Django框架,python编程设计语法。
解决的问题是如何更好的设计一个简易而方便操作前端的页面,解决数据间的关系,调整数据表的结构
该系统采用面向对象的程序设计方法,该方法是一种基于结构分析的以数据为中心的程序设计方法,其主要思想是将数据及处理这些数据的操作都封装在一个叫做类的数据结构里。这种方法描述的现实世界模型贴切、合理,更符合人们认识世界的思维方法。
详细视频演示
请联系我获取更详细的演示视频
技术路线
本系统的开发与设计是基于vue为前端页面核心框架为django/flask,技术方面主要采用了Html、Js、CSS3、python、Mysql。
本课题使用Python语言进行开发。代码层面的操作主要在PyCharm中进行,将系统所使用到的表以及数据存储到MySQL数据库中,方便对数据进行操作本课题基于WEB的开发平台
②前端开发选择:Vue。
②后端开发选择:python、django/flask。
③数据库选择:MySQL。
④开发工具选择:pycharm、Navicat for MySQL。
解决的思路
使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
使用PyCharm 导入项目,修改配置,运行项目;
将项目中config.ini配置文件中的数据库配置改为自己的配置,然后运行;
1.运行环境:python3.7/python3.8。
2.IDE环境:pycharm+mysql5.7/8.0+;
3.数据库工具:Navicat11
4.硬件环境:windows11/10 8G内存以上
5.数据库:MySql 5.7/8.0+版本;
运行成功后,在浏览器中输入:http://localhost:8080/项目名
本系统选择编程语言。Pymysql是封装了MySQL驱动的Python驱动一个能使Python连接到MySQL的库。Python语言官方规范访问数据库的统一接口规范(Python DB-API),防止在使用不同数据库时,由于底层数据库技术不同造成接口程序紊乱的问题。通过本次系统设计可以提高自己的编程能力,强化对所学知识的理解和运用
性能/安全/负载方面
在性能方面,系统应该能够支持多种用户访问,并且能够保证高效的运行速度。因此,在系统设计时,应该采用合理的技术手段来提高系统的性能,比如采用CDN技术,使用高性能的数据库等。
在可靠性方面,系统应该能够稳定运行,保证系统服务的可靠性和安全性。系统需要采用多种技术手段,如负载均衡、多版本控制、备份等来保证系统的可靠性和安全性。
最后,在安全方面,系统需要采用多层安全防御措施,保障用户数据的安全性和隐私性。同时,系统应该能够通过安全监测和日志审计等技术手段,实时掌握系统的运行状况,及时发现和解决安全问题。
可行性分析论证
该体系采用了 Django架构。Django是一个开放源码的 Web架构,它是 Python开发的,它拥有完全的架子功能。有了 Django, Python编程开发者可以很容易地实现一个正规站点所需的大多数,并在此基础上发展更多的 Web应用。Django自身是以 MVC模型为基础的,也就是模型+视图+ Controller (Controller)+ MVC (Controller)+ MVC (MVC)的优良特性,开发速度快,部署方便,可重用性高,维护成本低。Python和 Django是一个很好的结合,可以快速的开发,设计和部署网站。MySQL作为一款免费的开源软件,其功能也足以满足个人使用者和中小企业的需求。在此技术基础上搭建超市购物管理系统是可行的。总之,在技术层次,能够实现整个的水果推荐体系的发展。
软件开发人员并不需要很多钱,但专为个人独立,节省了大量的成本,并且还提高了个人的实际能力。所以本系统经济可行性较强,从节约成本出发,然后进行具体的系统的设计,在系统的设计过程中由于采用的所有开发工具都是免费的,因此不需要有任何的额外成本就可以进行该系统的设计。采用Django框架,系统升级方便,后期维护升级成本也较低。因此,本设计在经济上完全可行。
python-flask核心代码部分展示
import os
from flask import Blueprint
from utils.py_file_check import pyFileCheck
main_bp = Blueprint('main', __name__, static_folder='static')
import_str = 'from . import '
view_tuple = set()
exclude_list = [
# "common.py",
"__init__.py"
]
dir = os.path.join(os.getcwd(), "api/main")
dir = dir.replace("unit_test/", '') if "unit_test/" in dir else dir
for i in os.listdir(dir):
if i not in exclude_list and pyFileCheck(i) == True:
current = i.split(".", 1)[0]
view_tuple.add(current)
import_str += ','.join(view_tuple)
print(import_str)
exec(import_str)
python-django核心代码部分展示
# 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)
研究方法
(1)文献研究法:
文献研究法是根据一定的研究目的或课题,通过调查文献来获得资料,从而全面地、正确地了解掌握所要研究问题的一种方法。文献研究法被子广泛用于各种学科研究中。其作用有:能了解有关问题的历史和现状,帮助确定研究课题;能形成关于研究对象的一般印象,有助于观察和访问;能得到现实资料的比较资料;有助于了解事物的全貌。
(2)实证研究法:
实证研究法是科学实践研究的一种特殊形式。其依据现有的科学理论和实践的需要,提出设计,利用科学仪器和设备,在自然条件下,通过有目的有步骤地操纵,根据观察、记录、测定与此相伴随的现象的变化来确定条件与现象之间的因果关系的活动。主要目的在于说明各种自变量与某一个因变量的关系。
(3)经验总结法:
经验总结法是通过对实践活动中的具体情况,进行归纳与分析,使之系统化、理论化,上升为经验的一种方法。总结推广先进经验是人类历史上长期运用的较为行之有效的领导方法之一。1.进一步理解软件技术与理论知识。
感恩大学老师和同学
大学期间的学习时光对于我来说是美好而短暂的,在这期间我也接触了许多可爱的大学同学们,以及兢兢业业教学的老师们,在我的毕业论文即将完成之际,我想对那些曾经给予我支持,帮助,还有鼓励的同学和老师以及家人们表达我内心的无比感激之情。
感谢给予我论文指导的指导老师,从开题报告,任务书,论文大纲的编写与系统的功能框架设计,到最终的毕业论文,都是指导老师全程参与的悉心指导和帮忙,才能够让我的毕业论文可以符合学院要求编写完成。我的指导老师一丝不苟的教学精神以及在学术上的严谨作风,这些优点是值得我不断去努力学习的。
感谢大学同学的陪伴与帮助,在我独立编写毕业论文期间,大学同学的鼓励与耐心的帮助使得我少走很多弯路,节省毕业论文的编写时间,也让我有更多精力去完善我开发的系统。
在整个系统开发过程中,我周围的同学和朋友给了我很多意见,所以我很快就确认了系统的商业思想。在次,我由衷的向他们表示感激。
源码获取
需要成品,加我们的时候,记得把本页面标题截图发下我,方便查找相应的源代码。可以的话 顺便点赞!
文章最下方名片联系我即可~