(附源码)Django企业合同管理系统-计算机毕设 24692

Django企业合同管理系统

  

信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题。针对企业合同等问题,对如何通过计算机勤工俭学进行研究分析,然后开发设计出企业合同管理系统已解决问题。

企业合同管理系统主要功能模块包括个人资料、起草合同、起草合同、发票信息、合同存档、添加资金等,采取面对对象的开发模式进行软件的开发和硬体的架设,能很好的满足实际使用的需求,完善了对应的软体架设以及程序编码的工作,采取MySQL作为后台数据的主要存储单元,采用Django框架技术、Python编程语言、Ajax技术进行业务系统的编码及其开发,实现了本系统的全部功能。本次报告,首先分析了研究的背景、作用、意义,为研究工作的合理性打下了基础。针对企业合同管理系统的各项需求以及技术问题进行分析,证明了系统的必要性和技术可行性,然后对设计系统需要使用的技术软件以及设计思想做了基本的介绍,最后来实现企业合同管理系统和部署运行使用它。

关键词:合同管理;Django框架;MySQL数据库

Django Enterprise Contract Management System

Abstract

In the information society, there is a need for targeted information access, but the expansion of access is basically the direction of people's efforts. Due to the deviation of the perspective, people can often obtain different types of information, which is also the most difficult subject for technology to overcome. Aiming at the problems of enterprise contract, this paper studies and analyzes how to work study through computer, and then develops and designs the enterprise contract management system.

The main function modules of the enterprise contract management system include personal data, drafting contract, drafting contract, invoice information, contract archiving, adding funds, etc. , adopting object-oriented development mode to develop software and build hardware can meet the needs of actual use, perfect the corresponding software and programming work, taking MySQL as the main storage unit of background data, adopting Java technology and Ajax technology to code and develop the business system, all the functions of the system are realized. This report, first of all, analyzes the background, role and significance of the study, and lays a foundation for the rationality of the study. According to the requirements and technical problems of the enterprise contract management system, the necessity and technical feasibility of the system are proved, then it introduces the technical software and the design idea which the design system needs to use, finally realizes the enterprise contract management system and deploys to run to use it.

Key words: contract management; The Django Framework;  Mysql database

目  录

1     

1.1 课题背景与意义

1.2 开发现状 1

1.3 研究方法 2

2  系统关键技术 3

2.1 Pycharm简介 3

2.2 MySQL描述 3

2.3 Python编程语言 3

2.4 B/S结构 4

2.5 Django框架 4

3  系统分析 6

3.1 可行性分析 6

3.2功能需求分析 7

3.3 功能模块设计 9

3.4 业务流程分析 10

4 系统设计 12

4.1 系统架构设计 12

4.2系统功能结构 13

4.3 数据库设计 14

5 系统实现 22

5.1工作人员功能模块 22

5.2普通用户功能模块

5.3管理员功能模块

6  软件测试 28

6.1软件测试的重要性 28

6.2测试实例的研究与选择 28

6.3测试环境与测试条件 29

6.4系统运行情况 29

6.5系统评价 30

7 总结 31

参考文献 32

致谢 34

第1章  绪   论

1.1课题背景与意义

合同,又称契约,它是当事人双方或数方设立、变更和中止相互权利和义务关系的协议。合同制度在我国有着悠久的历史,合同作为一种企业之间横向联系的工具,是现代生产和商品交换高度发展的结果。

合同管理即合同行为的监督管理,是规范、制约、完善合同行为的一种活动,是国家法律赋予管理主体的一种职能,是企业在经济活动中保证企业利益的重要环节。改革开放以来,我国的经济建设取得了长足的发展,然而长期以来,由于在合同管理中实行手工作业,合同审批流程不明确,造成合同管理过程中业务处理效率低,浪费了大量的人力、物力,各部门之间合同流转时间长而且特别容易出错等问题。为了解决这一问题,需要开发一套功能完整的智能化的合同管理系统软件,用于各行各业的大中小型企业的合同制定、评审、实施动态控制等方面的具体应用需求,并以先进成熟的计算机网络和通信技术为手段,覆盖整个企业的各部门,实现该企业合同管理智能化,提高办公效率及人员的利用率成为促进企业迅速发展的一支很好的催化剂。

1.2 开发现状

随着微型计算机的出现和运算速度的提高,20世纪80年代后项目管理技术也呈现出繁荣发展的趋势,项目管理软件开始出现。对于大型项目管理,没有软件支撑,手工完成项目任务制定、跟踪项目进度、资源管理、成本预算的难度是相当大的。可以说计算机技术的发展对项目管理深入应用起了举足轻重的作用。根据管理对象的不同,项目管理软件可分为:①进度管理;②合同管理;③风险管理;④投资管理等软件。根据提高管理效率、实现数据信息共享等方面功能的实现层次不同,又可分为:①实现一个或多个的项目管理手段,如进度管理、质量管理、合同管理、费用管理,或者它们的组合等;②具备进度管理、费用管理、风险管理等方面的分析、预测以及预警功能;③实现了项目管理的网络化和虚拟化,实现基于Web的项目管理软件甚至企业级项目管理软件或者信息系统,企业级项目管理信息系统便于项目管理的协同工作,数据信息的实时动态管理,支持与企业项目管理有关的各类信息库对项目管理工作的在线支持。

随着IT行业的发展,IT行业内的项目拓展和投资比比皆是。为了提高项目管理水平,赢得市场竞争,特别是在加入WTO后在国内、国际市场上拥有与国际接轨的项目管理人才,越来越多的业界人士正通过不同的方式参加项目管理培训并力争获得世界上最权威的职业项目经理(PMP)资格认证。

国内外常用合同管理系统品牌:

1、国外项目管理软件有:Artemis公司ArtemisViewer;Welcom公司的OpenPlan等软件。

2、国内项目管理软件有:智邦国际项目管理软件、易建工程项目管理软件等。基本上是在借鉴国外项目管理软件的基础上,按照我国标准或习惯实现上述功能, 并增强了产品的易用性。

1.3研究方法

首先,通过引擎搜索或者查阅相关文献资料,了解了本系统开发的背景以及设计系统的意义所在,收集用户需求信息。其次,在开发工具上,最终确定选用Django框架来设计开发本系统,MySQL作为设计数据库的工具。用Python编程语言,并同数据库连接起来实现完整的通信功能。之后,设计出系统大致的功能模块。主要从方便系统用户和系统管理员的角度进行分析,明确该系统应该具有的功能。最终是测试系统,通过用例测试发现存在的问题并找到解决的方案。利用现有的开发平台,结合自己所学的知识,在老师的指导帮助下来完成该设计,确保系统的可用性、实用性。

  1. 系统关键技术

2.1 Pycharm简介

PyCharm是用于Python脚本语言的最流行的IDE。

1.每个文件都有其输出窗口。

2.可以终止进程(只要点下按钮就行)。

3.各种提示超强:①没用的变量颜色会变灰②用错了的变量下面会有红色波浪线③书写提示(sublime也有但较弱)。

4.索引功能超强。

2.2 MySQL描述

现在MySQL数据库在网络上它可以支撑许多个用户,而且也可以适应客服机和服务器的部署或者配置等,我们这里的服务器和客户机其实就是一种软件上的概念,并且我们使用的计算机硬件也与他们不存在一一对应的关系。

MySQL是一款非常流行的关系型数据库管理系统,它的出现一直都是佼佼者,它不仅功能非常强大,而且使用起来非常方便,并且MySQL的跨平台能力也很好,软件开发人员非常喜欢它的这些强大的优点。不同于其他关系型数据库,对于数据库的管理它有着自己的一套方案,通过对用户设定相应的权限和角色来达到对数据库的管理。由此可见,MySQL是一个能够适用于吞吐量高,可靠性高,效率高的一款数据库管理软件。

优点一:MySQL中对于不同身份的用户都设定其不同的权限来完成不同的业务逻辑,这使得MySQL在安全和完整性远远超出了其他关系型数据库。

优点二:对于那些动画、图形和声音的数据类型MySQL也可以支持,这说明多数据类型MySQL也是可以支持的。

优点三:MySQL还可以做到多个平台的开发,软件开发的多种编程语言都可以实现对MySQL数据库的操作。

2.3 Python编程语言

Python是一种开发语言,能够以直译的方式进行计算机语言,而且可以面向对象编程。它是由Guido van Rossum在十九世纪八十年代末研发出来,并且在九一年公开发行使用。Python有很多特点,比如有简洁的语法,清晰的语句,丰富的类库。正式由于这些优点,能够非常快速的和其他语言进行结合,来实现各种功能模块。很多人给它起了个外号叫“黏黏胶”语言。使用Python快速生成程序的原型,是现在很多程序员使用的方法。如果其中有比较特殊要求的地方,也非常方便的进行修改。

而且PyQt具有双证,为它能够跨平台运行(例如UNIX,微软和苹果的平台)提供了保证。

使用Python语言之前,要进行平台的安装,用户需要根据不同的平台,下载不同的版本,然后进行环境变量的配置,便可以进行运行。

Python 特点:

1.相对于其他计算机语言来说学习起来比较简单:Python的关键字较少,结构相对简单,语法简单,对于刚学编程语言的人来说更容易上手。

2.阅读起来也相对简单:Python代码结构简洁明了,并在定义上看起来也非常清晰,所以在阅读的过程中更加简单。

3.维护起来方便:Python的维护简单方便。

4.标准库特别广泛:Python的最大的最大优势是有非常多的库,而且是跨平台的,而且对系统的兼容性很好,比如在UNIX,Windows和Macintosh系统上都能够进行兼容。

5.具有方便的互动模式:有了互动模式的支持,开发者可以从代码就可以看到结果,这样开发者对程序的测试与调试,变的更方便。

6.可移植性好:Python可以跨平台运行。

7.扩展性非常好的:如果有关键的代码,你可以用特殊的语言进行编写,也能够在系统中调试运行。

2.4 Django框架

Django是一个由Python编写的具有完整架站能力的开源Web框架。使用Django,只要很少的代码,Python的程序开发人员就可以轻松地完成一个正式网站所需要的大部分内容,并进一步开发出全功能的Web服务。

Django本身基于MVC模型,即Model(模型)+View(视图)+ Controller(控制器)设计模式,因此天然具有MVC的出色基因:开发快捷、部署方便、可重用性高、维护成本低等。Python加Django是快速开发、设计、部署网站的最佳组合。

3章  系统分析

3.1 可行性分析

在软件开发的过程中系统的可行性分析是必不可少的,可行性的研究就是评估问题是否能得到解决并且是要以最少的时间和最少的代价来解决。为实现上面的目标还要必须考虑到解决这些问题的方法的优点和缺点,还要考虑到实现了这些系统规模的开发带来的经济效益。这里可以用技术的可行性,操作的可行性,经济的可行性对我们的系统进行可行性的研究。企业合同管理系统的可行性分析如下所示:

3.1.1技术可行性

企业合同管理系统采用的是Python编程语言并于Django框架,数据库部分采用的是当前流行的MYSQL数据库,企业合同管理系统中的所有数据资源都存储在Mysql数据库中,本系统多处采用了AJAX的异步操作,AJAX技术可以对用户指定部分的数据进行局部刷新,不仅减少了服务器对页面的解析而且极大增加了用户的体验度。。

3.1.2经济可行性

企业合同管理系统是在Mysql的环境中运行的,而系统的成本也只是主要分布在软件的开发和维护上。但如果系统上线投入使用之后,不仅可以方便人们,还节省了用户的时间和精力,而且还极大限度的方便了运营者,减少了运营者的工作强度。企业合同管理系统其实也不太复杂,在开发的时候经济支出也不大,在开发系统时时间用的也不多,从时间的优势和对经济利益方面产生的好处远超过维护和管理的成本,所以开发此系统是可行合适的。

3.1.3操作可行性

本系统是基于浏览器和服务器的企业合同管理系统,系统开发完成之后用户只需要在浏览器中输入正确的URL地址即可进行访问。本系统的前台页面简单明了,在没有操作指导的情况下也可以进行操作,无论是系统管理员还是普通用户在页面中所有的操作都是在浏览器中完成的,因此只要电脑在有网络的情况下,打开浏览器都能操作。而且在使用之前也不用进行相关的环境配置,因此本系统方便、简单、易于使用,所以该系统是容易并且可操作的。

3.2功能需求分析

本系统使用的角色大概分为工作人员、普通用户和管理员。

工作人员用例图如下所示。

图3-1 工作人员用例图

普通用户用例图如下所示。

图3-1 普通用户用例图

管理员用例图如下所示。

图3-3 管理员用例图

3.3 功能模块设计

企业合同管理系统功能具体有以下模块:

工作人员具体模块如下。

个人资料:修改个人信息,修改密码。
起草合同:工作人员可以新增填写合同信息,包括人员名称,工号,部门,法定人,合同类型,上传合同附件等信息。
申报信息:查看申报信息,提交审核状态,审核回复等。
发票信息:工作人员可以查询和新增发票信息。
合同存档:查看申请和确认的添加资金信息,提交审核状态。

普通人员具体模块如下。

个人资料:修改个人信息,修改密码。
起草合同:查看合同信息,下载合同附件等操作。
申报信息:查看申报信息内容,修改申报信息内容等。
合同存档:用户可以查看合同编号,工作人员名称以及其他合同信息存档。
添加资金(申请):查看申请的添加资金信息。
添加资金(确认):查看确认的添加资金信息。

管理员具体模块如下。

个人资料:修改个人信息,修改密码。
用户管理:管理和所有注册用户信息资料,添加工作人员信息,提交注册用户的审核状态。
权限管理:管理员设定权限管理列表。
部门管理:可以查看和新增删除部门信息。
合同类型:可以查看和新增删除合同类型信息。

3.4 业务流程分析

3.4.1登录流程

登录模块主要满足管理员以及用户的权限登录,用户登录流程图如图3-1所示。

图3-1 登录流程图

3.4.2注册流程

未有账号的用户可进入注册界面进行注册操作,用户注册流程图如图3-2所示。

图3-2 注册流程图

3.4.3添加信息流程

用户在添加信息时,信息编号自动生成,系统会对添加的信息进行验证,验证通过则添加至数据库,添加信息成功,反之添加失败。添加信息流程如图3-3所示。

图3-3 添加信息流程图

3.4.4删除信息流程

用户可选择要删除的信息进行信息删除操作,在删除信息时系统提示是否确定删除信息,是则删除信息成功,系统数据库将信息进行删除。删除信息流程图如图3-4所示。

图3-4删除信息流程图

4章 系统设计

4.1 系统架构设计

由于本系统在逻辑事务处理方面对数据库的操作比较频繁所以系统在底层连接数据库封装之后相当于一个连接数据库的工具DB UTIL,这样使用起来会更加方便而且这样进行封装还可以降低系统中代码的冗余,当我们需要连接和使用数据库时只需要调用这个工具里面的一个方法就可以了。而且通过封装可以把对数据库的操作独立起来,当需要连接不同种类的数据库时只需要加以修改就可以达到目的。

DAO层本来并无这个类,它只是Python中MVC构造里的一个model概念,主要就是里面的一些方法,而这些方法就是用来访问数据库的方法。我们在软件开发时DAO层我们一般都放接口和接口的实现类,用于来规范实现类的我们叫它接口,实现类重点用于对数据库的操纵。

MVC是一种系统研发的关键模型,M是Model模型,它是系统内部关键程序运行的核心,主要进行对数据库的各种操作。视图View是V也叫做视图,主要的作用是对一些数据进行显示。控制器Controller 是C执行从View的视图层来读取数据,然后控制用户的输入。

图4-1系统架构图

4.2系统功能结构

进入系统后首先要进行登录,验证你的身份,赋予你不同的权限。当你成功登录后,页面会有多个板块,分别是系统用户管理、个人资料、起草合同、申报信息、合同存档、添加资金、权限管理。里面界面简单易懂,根据标示可以直接进行方便快捷的操作。

系统功能结构图如下所示。

图4-2系统功能结构图

4.3 数据库设计

数据库可以说是所有软件的根本,如果数据库存在缺陷,那么会导致系统开发的不顺利、维护困难、用户使用不顺畅等一系列问题,严重时将会直接损害企业的利益,同时在开发完成后,数据库缺陷也更加难以解决。所以必须要对数据库设计重点把握,做到认真细致。因此,数据库设计是这个企业合同管理系统的重点要素。

4.3.1数据库概念设计

根据前面的数据流程图,结合系统的功能模块设计,设计出符合系统的各信息实体。

管理员信息属性图如图4-4所示。

 4-3 管理员信息实体属性图

用户信息实体属性图如图4-4所示。

图4-4用户信息实体属性图

4.3.2数据库表设计

将数据库概念设计的E-R图转换为关系数据库。在关系数据库中,数据关系由数据表组成,但是表的结构表现在表的字段上。

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

token_id

int

10

0

N

Y

临时访问牌ID

2

token

varchar

64

0

Y

N

临时访问牌

3

info

text

65535

0

Y

N

4

maxage

int

10

0

N

N

2

最大寿命:默认2小时

5

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

7

user_id

int

10

0

N

N

0

用户编号:

表add_funds_application (添加资金(申请))

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

add_funds_application_id

int

10

0

N

Y

添加资金(申请)ID

2

declaration_number

varchar

64

0

N

N

申报号

3

contract_no

varchar

64

0

Y

N

合同编号

4

working_personnel

int

10

0

Y

N

0

工作人员

5

employee_id

varchar

64

0

Y

N

员工工号

6

employee_name

varchar

64

0

Y

N

员工姓名

7

contract_name

varchar

64

0

Y

N

合同名称

8

date_prepared

date

10

0

Y

N

起草日期

9

enterprise_id

varchar

64

0

Y

N

企业编号

10

department

varchar

64

0

Y

N

部门

11

legal_representative

varchar

64

0

Y

N

法定人

12

type_of_contract

varchar

64

0

Y

N

合同类型

13

appendices_of_a_contract

varchar

255

0

Y

N

合同附件

14

ordinary_users

int

10

0

Y

N

0

普通用户

15

user_name

varchar

64

0

Y

N

用户姓名

16

increase_funds

int

10

0

Y

N

0

增加资金

17

add_reason

text

65535

0

Y

N

添加原因

18

examine_state

varchar

16

0

N

N

未审核

审核状态

19

examine_reply

varchar

16

0

Y

N

审核回复

20

recommend

int

10

0

N

N

0

智能推荐

21

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

22

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表add_funds_confirm (添加资金(确认))

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

add_funds_confirm_id

int

10

0

N

Y

添加资金(确认)ID

2

declaration_number

varchar

64

0

N

N

申报号

3

contract_no

varchar

64

0

Y

N

合同编号

4

working_personnel

int

10

0

Y

N

0

工作人员

5

employee_id

varchar

64

0

Y

N

员工工号

6

employee_name

varchar

64

0

Y

N

员工姓名

7

contract_name

varchar

64

0

Y

N

合同名称

8

date_prepared

date

10

0

Y

N

起草日期

9

enterprise_id

varchar

64

0

Y

N

企业编号

10

department

varchar

64

0

Y

N

部门

11

legal_representative

varchar

64

0

Y

N

法定人

12

type_of_contract

varchar

64

0

Y

N

合同类型

13

appendices_of_a_contract

varchar

255

0

Y

N

合同附件

14

ordinary_users

int

10

0

Y

N

0

普通用户

15

user_name

varchar

64

0

Y

N

用户姓名

16

increase_funds

int

10

0

Y

N

0

增加资金

17

add_reason

text

65535

0

Y

N

添加原因

18

recommend

int

10

0

N

N

0

智能推荐

19

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

auth_id

int

10

0

N

Y

授权ID:

2

user_group

varchar

64

0

Y

N

用户组:

3

mod_name

varchar

64

0

Y

N

模块名:

4

table_name

varchar

64

0

Y

N

表名:

5

page_title

varchar

255

0

Y

N

页面标题:

6

path

varchar

255

0

Y

N

路由路径:

7

position

varchar

32

0

Y

N

位置:

8

mode

varchar

32

0

N

N

_blank

跳转方式:

9

add

tinyint

3

0

N

N

1

是否可增加:

10

del

tinyint

3

0

N

N

1

是否可删除:

11

set

tinyint

3

0

N

N

1

是否可修改:

12

get

tinyint

3

0

N

N

1

是否可查看:

13

field_add

text

65535

0

Y

N

添加字段:

14

field_set

text

65535

0

Y

N

修改字段:

15

field_get

text

65535

0

Y

N

查询字段:

16

table_nav_name

varchar

500

0

Y

N

跨表导航名称:

17

table_nav

varchar

500

0

Y

N

跨表导航:

18

option

text

65535

0

Y

N

配置:

19

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表contract_archiving (合同存档)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

contract_archiving_id

int

10

0

N

Y

合同存档ID

2

declaration_number

varchar

64

0

N

N

申报号

3

contract_no

varchar

64

0

Y

N

合同编号

4

working_personnel

int

10

0

Y

N

0

工作人员

5

employee_id

varchar

64

0

Y

N

员工工号

6

employee_name

varchar

64

0

Y

N

员工姓名

7

contract_name

varchar

64

0

Y

N

合同名称

8

date_prepared

date

10

0

Y

N

起草日期

9

enterprise_id

varchar

64

0

Y

N

企业编号

10

department

varchar

64

0

Y

N

部门

11

legal_representative

varchar

64

0

Y

N

法定人

12

type_of_contract

varchar

64

0

Y

N

合同类型

13

appendices_of_a_contract

varchar

255

0

Y

N

合同附件

14

ordinary_users

int

10

0

Y

N

0

普通用户

15

user_name

varchar

64

0

Y

N

用户姓名

16

investing_funds

int

10

0

Y

N

0

投入资金

17

invoice

varchar

255

0

Y

N

发票

18

recommend

int

10

0

N

N

0

智能推荐

19

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

20

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表declaration_information (申报信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

declaration_information_id

int

10

0

N

Y

申报信息ID

2

declaration_number

varchar

64

0

Y

N

申报号

3

contract_no

varchar

64

0

Y

N

合同编号

4

working_personnel

int

10

0

Y

N

0

工作人员

5

employee_id

varchar

64

0

Y

N

员工工号

6

employee_name

varchar

64

0

Y

N

员工姓名

7

contract_name

varchar

64

0

Y

N

合同名称

8

date_prepared

date

10

0

Y

N

起草日期

9

enterprise_id

varchar

64

0

Y

N

企业编号

10

department

varchar

64

0

Y

N

部门

11

legal_representative

varchar

64

0

Y

N

法定人

12

type_of_contract

varchar

64

0

Y

N

合同类型

13

appendices_of_a_contract

varchar

255

0

Y

N

合同附件

14

ordinary_users

int

10

0

Y

N

0

普通用户

15

user_name

varchar

64

0

Y

N

用户姓名

16

investing_funds

int

10

0

Y

N

0

投入资金

17

reason_for_declaration

text

65535

0

Y

N

申报原因

18

examine_state

varchar

16

0

N

N

未审核

审核状态

19

examine_reply

varchar

16

0

Y

N

审核回复

20

recommend

int

10

0

N

N

0

智能推荐

21

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

22

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表drafting_contracts (起草合同)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

drafting_contracts_id

int

10

0

N

Y

起草合同ID

2

contract_no

varchar

64

0

Y

N

合同编号

3

working_personnel

int

10

0

Y

N

0

工作人员

4

employee_id

varchar

64

0

Y

N

员工工号

5

employee_name

varchar

64

0

Y

N

员工姓名

6

contract_name

varchar

64

0

Y

N

合同名称

7

date_prepared

date

10

0

Y

N

起草日期

8

enterprise_id

varchar

64

0

Y

N

企业编号

9

department

varchar

64

0

Y

N

部门

10

legal_representative

varchar

64

0

Y

N

法定人

11

type_of_contract

varchar

64

0

Y

N

合同类型

12

appendices_of_a_contract

varchar

255

0

Y

N

合同附件

13

contract_description

longtext

2147483647

0

Y

N

合同说明

14

recommend

int

10

0

N

N

0

智能推荐

15

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

16

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

5章 系统实现

5.1工作人员功能模块

企业合同管理系统,在系统功能页面可以查看个人资料、起草合同、申报信息、发票信息、合同存档、添加资金等内容,如图5-1所示。

图5-1系统功能界面图

起草合同,在起草合同页面可查看和添加合同信息,填写人员名称,工号,部门,法定人,合同类型,上传合同附件等信息,如图5-2所示。

图5-2起草合同添加界面图

    申报信息,工作人员可查看申报信息,提交审核状态,审核回复等,如图5-3所示。

图5-3申报信息界面图

5.2普通用户功能模块

普通用户注册登录系统,通过填写注册时输入的用户名、密码、角色、验证码进行登录,注册成功的用户都需要管理员审核通过才能登录。注册如图5-4所示。

图5-4用户注册界面图

 申报信息,用户可以填写申报信息内容。如图5-5所示。

图5-5申报信息填写界面图

    添加资金(申请),用户对于未通过审核的申报信息进行增加资金操作,填写增加资金信息。如图5-6所示。

图5-6添加资金(申请)界面图

5.3管理员功能模块

管理员登录,通过填写注册时输入的用户名、密码、角色、验证码进行登录,如图5-7所示。

图5-7管理员登录界面图

管理员登录进入企业合同管理系统可以查看个人资料、用户管理、权限管理、部门管理、合同类型等信息,如图5-8所示。

图5-8用户管理界面图

权限管理,在权限管理页面中可以查看用户组、权限名称、添加权限、删除权限、查询权限、新增时间等信息,如图5-9所示。

图5-9权限管理界面图

部门管理,在部门页面中可以查看部门、新增时间、更新时间等信息,并可根据需要进行修改或删除等操作,如图5-10所示。

图5-10部门界面图

合同类型,在合同类型页面中可以添加合同类型等操作,如图5-11所示。

图5-11合同类型界面图

第6章  软件测试

测试存在于软件开发进程中的最后一个阶段,它可以保证一个软件的开发质量是否符合设计者的初衷,也为程序的正式上线做了最后一道质量检测的工序。软件测试主要是控制各种条件、包括软件输出方式,使用模式和运行环境等,来评估一个系统或应用是否符合设计标准。在软件测试过程中,我们一般刻意的去制造错误和极端条件,不能仅依照正常模式允许,而是多去尝试那些意外的情况。

6.1软件测试的重要性

只有在运行和维护阶段之前经历大量的测试的软件,才能说明它的质量是经得起检验的。最近计算机业界也都一致认为,测试应该存在于软件设计的每个阶段,因为越早发现错误,修复起来就越容易。

实际上,对于一个软件应用,错误是必然存在的,无论使用何种技术或手段,都不可能绝对的排除软件漏洞。测试是随着软件开发一同诞生的,两者是共同发展进步的。实际上,测试可以大幅度的降低维护的成本,如果一个漏洞在开发的早期就被发现,那么修复它的成本远比上线后再修复的成本要低得多。

6.2测试实例的研究与选择

测试有白盒测试和黑盒测试两种方式。

其中,白盒测试是将软件看成一个透明的白盒子,按照程序的内部控制结构和处理技术逻辑来选定测试用例、软件系统测试的逻辑路径及过程需要进行管理测试,又称玻璃盒测试。因此白盒测试需要选择足够多的测试用例,覆盖尽可能多的代码来发现程序中的错误。

黑盒测试,也称为功能测试。它将需软件看作一个黑盒,像一个普通用户一样来模拟软件的使用流程。黑盒测试通过大量的输入边界值或错误数据,来检查是否可产生正确的输出。

本系统测试 主要选择黑盒测试,少量采用白盒测试。通过测试达到以下测试目的:

1.检查各大功能模块的运行,确保其能够正确运行,并检查各页面的完整性,保证页面完整。

2.检查各个接口是否可以正确地输入和输出,保证数据流通稳定可行。

3.检查数据结构,保证其和外部接口没有访问错误,访问顺利。

4.检查原计划的性能需求有没有完成,运行流畅。

本系统的测试用例(部分):

登录部分测试用例

编号

对象

项目

操作

预期结果

结果

1

登录

登录提示

使用正确的账号密码登录

成功登录

预期结果

2

登录提示

使用正确的账号但错误的密码登录

提示密码错误

预期结果

3

登录提示

使用错误的账号登录

提示不存在账户

预期结果

4

登录提示

不输入账号,点击登录

提示输入账号

预期结果

5

登录提示

输入账号但不输入密码点击登录

提示输入密码

预期结果

6

登录入口

已登录账号,查看登录入口

不显示登录入口

预期结果

6.3测试环境与测试条件

处理器:Inter Core I7-4710MQ四核处理器

内存:4GB

硬盘:1T

操作系统:Windows 10

数据库:MySQL

6.4系统运行情况

全部测试用例都已通过(包括但不限于以上测试用例),且不存在漏洞,实现了论文开始时所作要求。本系统运行稳定,使用流畅,可以满足用户需求。

6.5系统评价

6.5.1系统功能评价

试运行后进行系统评估,可以认为该系统达到预定的目标要求,可以满足用户的需求,也满足了系统开发前所作目标。

6.5.2系统技术评价

系统在经过大量重复测试后运行十分稳定,安全实用,功能模块已经达到预定目标所需。

6.5.3系统经济评价

在规定的时间内实现系统的大部分功能,且满足要求,节省开发成本,有助于提高科学管理水平,符合本人经济情况。


第7章 总结

2023年的今天,计算机技术已经相当成熟。它的发展推动了许多行业改头换面,计算机的出现使人类社会有了进一步降低人力物力和资源的方法,提高了人类社会的生产力,转变了社会生产方式。目前在线都在积极备战,发展计算机和互联网,结合自身优势进军互联网行业成为各大企业的重点项目。

本文利用Django和MySQL数据库技术,通过分析现实在线业务流程的基础上,并完成了企业合同管理系统。经调试结果显示,本系统基本可以满足一个企业合同管理系统的业务需要。系统界面简洁而有美感, 易操作,做出了自己的特色,然而因为时间仓促再加上缺乏系统开发经验和仅依靠少数问卷调查方式,因此本系统还存在不少缺陷、不足,比如:

1. 数据输入的格式并没有全部检验,所以很难保证数据的准确,可能有一些不符合规则的数据也可以通过检验。

2. 系统功能还不够完善,无法提供丰富多彩的在线功能,只能实现用户管理、权限管理、部门管理、合同类型、起草合同、申报信息、发票信息等一系列功能。

本系统还存在一些漏洞没有解决,在现实应用情境中很难保证完全不出错,但相信通过再次完善,可以调试出真正符合实际的企业合同管理系统。


参考文献

[1]王玉芬,别好杰.基于Django的企业门户网站的设计与实现[J].电脑知识与技术,2023,19(04):53-55.

[2]叶欣宇.基于Django的用户唯一性安全登录系统设计[J].信息与电脑(理论版),2023,35(02):114-116.

[3]王玉芬,赵丹丹.基于Bootstrap和Django框架的Web计算器的设计与实现[J].信息与电脑(理论版),2023,35(01):143-146.

[4]刘晴,吴晓玥,张丽芸,王泽鹏.智能化模式下企业合同管理系统的优化[J].企业科技与发展,2022(07):70-72.

[5]林彬,杨彬彬,孙芳.基于Django框架的高校就业信息可视化平台的设计与实现[J].辽宁师范大学学报(自然科学版),2022,45(02):201-208.

[6]刘恒,徐蓓蓓,李成龙,贺思鞠.基于BPM的某企业合同管理系统设计与应用[J].企业科技与发展,2022(05):58-61.

[7]冼远清,张旭新.基于Django的图书推荐系统设计[J].电子技术与软件工程,2022(05):216-219.

[8]吕奎. 基于Django框架的发酵技术云服务器开发[D].江南大学,2021.

[9]贺斐. 企业合同管理系统的设计与实现[D].西安电子科技大学,2020.

[10]李阳. 基于B/S的制造型企业合同管理系统的设计与实现[D].西安电子科技大学,2020.

[11]郭瀛.合同管理系统在企业管理创新中的应用研究[J].大众投资指南,2019(21):100-101.

[12]李燕,沈涛,方攀.企业合同管理系统功能设计探析[J].中国市场,2019(02):101-102.

[13]吴迪.中小企业合同管理系统的设计与研发[J].电脑知识与技术,2019,13(09):81-82.

[14]孙威. 基于Django和数据库优化策略的比特币信息查询系统[D].东华大学,2019.

[15]赵艳斌.基于Django技术的网页数据模型建立[J].时代农机,2019,42(07):27-28+30.

[16] Xian Yuanqing and Zhang Xuxin. Design of book recommendation system based on Django [ J ] . Electronic Technology and Software Engineering, 2022(05) : 216-219.


                                   

大学生活在这个时候即将划上一个句号,但是对于我的人生道路来说,这仅仅是一个逗号,我将面对的是又一次征程的开始。

回忆过去,许许多多的事情浮现在脑海:刚上大学时欢乐心情和兴奋的场景还历历在目。一切都是那么新鲜,那么富有吸引力。有快乐也有艰辛,有收获也有失落。衷心感谢信息学院所有支持帮助过我的老师,谢谢你们多年来的关心和爱护。同窗的友情同样难忘,你们与我共同走过了人生中不平凡的道路,给我留下了值得珍藏的美好记忆。

最后,我要特别感谢指导企业合同管理系统论文设计的老师。本论文是在他的悉心指导和热情帮助下完成的,老师认真负责的工作态度,严谨的治学精神和精深的理论水平都使我受益匪浅。老师无论在理论上还是在实践中,都给予我很大的帮助,使我专业技能的应用水平得到很大提高,这对于我以后的工作和学习都有益处。值此论文完成之际,特别向老师表示衷心的感谢和崇高的敬意,谢谢他细心而又耐心地辅导,使得我得以顺利的完成毕业设计开发工作,同时也要感谢其他帮助过我的老师和同学,他们在我成长过程中给予了我很大的帮助,在此一并表示感谢。

由于本人水平有限,加上时间紧促,本文一定有不少缺点和不足,恳请各位老师给予帮助和指正。

请关注点赞+私信博主,免费领取项目源码

  • 46
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
**Python Django社团管理系统:高度可定制的毕设** **一、资概述** 本资是一套基于Python语言和Django框架开发的社团管理系统。它旨在帮助高校社团轻松实现成员管理、活动组织、信息发布等日常功能,同时支持二次开发和个性化定制,非常适合作为计算机专业的毕业设计项目。 **二、核心功能** 1. **用户管理**:系统支持学生和教师两种角色,可进行注册、登录、权限分配等操作。 2. **社团管理**:创建、编辑和删除社团,查看社团详细信息,管理社团成员。 3. **活动管理**:发布、修改和删除活动,在线报名,活动考勤,活动总结。 4. **通知公告**:发布社团相关通知和公告,支持图文格式。 5. **文件管理**:上传、下载和管理社团相关的文件资料。 6. **数据统计**:统计社团成员数量、活动参与度等信息,生成可视化图表。 **三、技术特点** 1. **前后端分离**:前端采用HTML、CSS和JavaScript技术,后端使用Django框架,实现了前后端的解耦,便于维护和升级。 2. **数据库设计**:采用MySQL数据库,设计了完善的表结构,保证了数据的完整性和一致性。 3. **模块化开发**:系统各功能模块独立开发,降低了耦合度,提高了代码的可重用性。 4. **RESTful API**:提供了丰富的API接口,方便与其他系统集成或进行二次开发。 **四、适用对象** 1. 计算机专业学生:可作为毕业设计项目,锻炼编程能力和解决实际问题的能力。 2. 社团负责人:用于管理社团日常事务,提高工作效率。 3. 软件开发者:参考代码进行二次开发,满足个性化需求。 **五、获取方式** 本资为.rar压缩包形式,包含代码、数据库脚本、说明文档等全部内容。请通过合法途径获取,并在下载后遵守相关版权法规。
Django是一个使用Python语言开发的Web框架,用于快速构建高效的Web应用程序。而资产管理系统是一种用于管理企业或组织内部所有资产的系统,在这个系统中可以对固定资产、无形资产、流动资产等进行统一的管理和维护。 Django资产管理系统码是指使用Django框架开发的一套资产管理系统代码。这套码可以用于快速搭建一个完善的资产管理系统,并根据实际需求进行个性化定制。它提供了一些常用的资产管理功能,比如资产登记、资产查询、资产调拨、资产盘点等。 使用Django资产管理系统码可以带来以下好处: 1. 快速开发:Django框架提供了一系列的工具和功能,可以帮助开发者快速搭建一个完整的Web应用程序。使用资产管理系统码可以减少开发时间和工作量,从而更快地推出产品或服务。 2. 灵活定制:码提供了一些常用的资产管理功能,但可以根据实际需要进行个性化定制。开发者可以根据自己的业务需求添加、修改或删除功能,使系统更符合实际应用场景。 3. 高效运行:Django框架具有高性能和高效率的特点,能够处理大量的并发请求。这对于资产管理系统来说尤为重要,因为资产数据的变动频繁,需要能够快速响应用户的操作。 总之,使用Django资产管理系统码可以帮助企业或组织快速搭建一个高效的资产管理系统,提高资产管理的效率和质量。同时,码也提供了一个可扩展的平台,可以根据实际需求进行个性化开发和定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值