基于Python的毕业生档案管理系统-毕业设计源码40217

摘要

随着高等教育的普及和大量毕业生的涌现,如何有效管理和利用毕业生档案成为了高校和教育机构面临的重要问题。传统的纸质档案管理方式已经无法满足档案管理的需求,因此需要引入信息技术和自动化流程来提升档案管理的效率和准确性。本研究旨在开发一款高效的毕业生档案管理系统。该系统将实现毕业生个人信息的录入、参加职业培训、查询管理档案等功能,为高校提供一个全面的毕业生档案管理解决方案。

本研究选择采用Python编程语言、Django框架和MySQL数据库进行系统的开发。Python是一种简洁而强大的编程语言,Django框架则提供了快速搭建Web应用程序所需的工具和功能。MySQL作为一种成熟可靠的关系型数据库,能够确保数据的安全性和稳定性。通过本研究的实施,期望能够开发出一款高效、准确且易于使用的毕业生档案管理系统,为高校提供便捷的档案管理和就业支持服务,促进毕业生的顺利就业和职业发展。

关键词:毕业生档案管理系统;Python;Django;MYSQL数据库

Abstract

With the popularization of higher education and the emergence of a large number of graduates, how to effectively manage and utilize graduate files has become an important issue faced by universities and educational institutions. The traditional paper-based archive management method can no longer meet the needs of archive management, so it is necessary to introduce information technology and automated processes to improve the efficiency and accuracy of archive management. This study aims to develop an efficient graduate file management system. This system will achieve functions such as inputting personal information of graduates, participating in vocational training, and querying and managing files, providing a comprehensive solution for graduate file management for universities.

This study chose to use Python programming language, Django framework, and MySQL database for system development. Python is a concise and powerful programming language, while the Django framework provides the tools and features needed to quickly build web applications. MySQL, as a mature and reliable relational database, can ensure the security and stability of data. Through the implementation of this study, it is expected to develop an efficient, accurate, and easy-to-use graduate record management system, providing convenient record management and employment support services for universities, and promoting the smooth employment and career development of graduates.

Keywords: Graduate file management system; Python; Django; MYSQL database.

目录

摘要

Abstract

第 1 章 引  言

1.1 选题背景

1.2 国内外研究现状

1.3 论文结构安排

第 2 章 系统需求分析

2.1 系统可行性分析

2.1.1 技术可行性分析

2.1.2 经济可行性分析

2.1.3 操作可行性分析

2.2 系统需求分析

2.2.1 功能需求分析

2.2.2 非功能性需求分析

2.3 系统用例分析

第 3 章 系统总体设计

3.1 系统功能模块设计

3.2 数据库设计

3.2.1 数据库概念结构设计

3.2.2 数据库逻辑结构设计

第 4 章 关键模块的设计与实现

4.1 登录模块

4.2 注册模块

4.3 用户管理模块

4.4 留言区模块

4.5 就业指导模块

4.6 职业培训模块

4.7 学生档案模块

4.8 申请证书模块

4.9 发放证书模块

第 5 章 系统实验与结果分析

5.1 测试的目的

5.2 系统部分测试

5.3 系统测试结果

第 6 章 结论

参考文献

致谢

  • 1 章 引  言
    1. 选题背景

毕业生档案管理系统是一种应用于高校或教育机构的信息管理系统,旨在对毕业生的个人信息、学习成绩、就业情况等进行有效的管理和记录。随着高等教育的普及和大量毕业生的涌现,传统的手工档案管理方式已经无法满足档案管理的需求。过去,毕业生档案通常以纸质形式存储,需要大量的物理空间和人力资源来维护和管理。同时,由于信息不易获取和整理,档案的查询和使用效率较低。此外,在毕业生就业方面,传统的档案管理方式也往往无法提供及时准确的数据分析和统计。因此,毕业生档案管理系统的研究和开发具有重要意义。通过引入信息技术和自动化流程,毕业生档案管理系统可以实现毕业生个人信息的录入、参加职业培训、查询管理档案等功能。该系统可以提高档案管理的效率和准确性,方便高校和教育机构对毕业生信息的管理和利用。

传统的纸质档案管理方式耗时耗力,容易出现信息丢失和混乱。毕业生档案管理系统的引入可以实现电子化档案管理,提高档案管理的效率和准确性。通过系统的录入、存储和查询功能,可以快速方便地查找和更新毕业生的个人信息和学籍资料。毕业生档案管理系统可以有效利用信息技术和自动化流程,减少了传统档案管理所需的人力和物力资源。这样可以节省成本,并将资源投入到更有价值的教育和就业服务中,提升教育机构的整体效益。毕业生档案管理系统可以记录和管理毕业生的就业情况、就业单位信息等数据。这些数据可以为高校和教育机构提供有力的支持,进行就业数据分析、就业指导和职业规划等工作。通过系统的数据统计和报表生成功能,可以及时了解毕业生的就业状况和趋势,为学校制定更科学的人才培养方案提供参考。毕业生档案管理系统可以为高校和教育机构的教育工作提供数据支持和决策依据。通过系统中的学生成绩记录和评价信息,可以对教学质量进行评估和改进。同时,系统中的个人信息和学籍资料可以为学生的教育发展提供参考和指导,促进个性化教育的实施。毕业生档案管理系统收集了大量的毕业生数据,包括个人信息、学习成绩、就业情况等。这些数据可以进行统计分析和研究,探索毕业生教育与就业的关系、影响因素等。通过数据分析和研究,可以为高校和教育机构提供更科学的决策依据,优化毕业生培养和就业服务。

    1. 国内外研究现状

在国内,毕业生档案管理系统的研究和应用逐渐受到高校和教育机构的重视,并取得了一些进展。国内的研究团队和公司开始关注毕业生档案管理系统的设计和开发。他们利用信息技术和数据库管理技术,构建了具有个人信息录入、档案查询、数据分析、报表生成等功能的系统。这些系统可以提高档案管理的效率和准确性。一些高校已经推出了电子学籍系统,将毕业生的个人信息、学习成绩等数字化存储和管理。这样可以方便高校对毕业生的学籍信息进行管理和查询,并提供数据支持和决策依据。国内的研究者开始关注毕业生就业信息的管理和利用。通过毕业生档案管理系统,可以记录和管理毕业生的就业情况、就业单位信息、薪资水平等数据。这些数据可以用于高校和教育机构的统计分析,为毕业生的就业指导、职业规划和人才培养提供有力支持。实践应用案例:一些高校已经开始使用毕业生档案管理系统,并取得了一定的效果。这些应用案例可以为其他高校提供借鉴和参考,促进毕业生档案管理系统的推广和应用。

在国外,毕业生档案管理系统的研究和应用也取得了显著进展。国外的研究机构和公司已经推出了多种毕业生档案管理系统,具有个人信息录入、档案查询、数据分析、报表生成等功能。这些系统基于先进的信息技术和数据库管理技术,能够提高档案管理的效率和准确性。国外一些高校和教育机构使用学生信息管理系统来管理毕业生的个人信息、学习成绩、就业情况等数据。通过该系统,可以方便地查找和更新毕业生的档案信息,并提供数据支持和决策依据。一些国外的高校和教育机构建立了毕业生就业服务平台,提供毕业生的个人信息、求职意向、就业机会等信息。这些平台可以帮助毕业生与潜在雇主联系,提供就业指导和资源,促进毕业生的顺利就业。国外的一些研究机构和高校对毕业生数据进行统计分析和研究。他们通过毕业生档案管理系统收集和整理大量的毕业生数据,探索教育与就业之间的关系、影响因素等。通过数据分析和研究,可以为高校和教育机构提供更科学的决策依据,优化毕业生培养和就业服务。在一些跨国合作项目中,国外的高校和教育机构积极开展毕业生档案管理系统的研究和实践。他们通过共享数据和经验,探索不同国家和地区的毕业生档案管理模式和最佳实践。

综上所述,国外毕业生档案管理系统的研究和应用已经取得了显著进展。通过引入先进的信息技术和创新的管理方法,这些系统能够提高档案管理的效率、准确性和应用价值。同时,国外的研究还关注毕业生就业服务、数据分析和国际合作等领域的发展,为毕业生档案管理系统的进一步创新和应用提供了有益借鉴。

    1. 论文结构安排

论文将分层次经行编排,除去论文摘要致谢文献参考部分,正文部分还会对系统需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:

第1章 交代项目的背景、开发这个系统的现状以及论文的章节安排情况。

第2章 对系统的具体需求展开分析。

第3章 阐述了系统的设计,其中涵盖了功能设计以及数据库的设计。

第4章 阐明了毕业生档案管理系统各个功能模块的实现,以图文的形式进行展示。

第5章 罗列了部分系统调试与测试的记录。

第6章 介绍了毕业生档案管理系统的结论。

毕业生档案管理系统存储所使用的是MySQL数据库以及开发中所使用的是pycharm等开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用Django框架进行开发,使系统的可扩展性和维护性更佳,减少Python配置代码,简化编程代码,目前Django框架也是很多企业选择的框架之一。

      1. 经济可行性分析

在开发毕业生档案管理系统中所使用的pycharm开发工具、Vs CodeHbuildX、MySQL数据库等工具都是开源免费的,这些环境在学校都进行了系统的学习,自己能够独立操作完成,不需要额外花费,而且系统的开发工具从网上都可以直接下载,因此在经济方面是可行的。

      1. 操作可行性分析

此次项目设计的时候我参考了很多类似系统的成功案例,对它们的操作界面以及功能都进行了系统的分析,将众多案例结合在一起,突出以人为本简化操作,所以具有基本计算机知识的人都会操作本项目。因此操作可行性也没有问题。

    1. 系统需求分析
      1. 功能需求分析

毕业生档案管理系统为普通用户和管理员提供了一系列功能。对于普通用户来说,他们可以通过系统的首页了解学校/机构的基本信息和最新动态,参与交流论坛并与其他用户分享经验,获取就业指导资源,留言区进行沟通与互动,参与职业培训活动,管理个人中心和学生档案,申请和发放证书,报名参加各类活动,并将感兴趣的帖子、资源或课程收藏起来。而管理员则可以通过后台首页监控系统运行情况,管理系统用户和权限,处理学生档案和证书申请,管理职业培训和报名活动,管理轮播图和留言板,以及管理就业指导资源和交流论坛内容。通过这些功能,毕业生档案管理系统提高了档案管理效率,促进了用户之间的交流与合作,满足了普通用户和管理员的不同需求。具体如下。

普通用户端:

  1. 交流论坛:提供一个交流平台,让用户可以在论坛上发表帖子、回复评论,与其他用户分享经验和交流信息。
  2. 就业指导:提供就业指导资源,如职业规划、求职技巧、简历撰写等,帮助用户更好地进行就业准备和求职。
  3. 留言区:用户可以在留言区留下意见、建议或问题,并与管理员或其他用户进行交流和互动。
  4. 职业培训:提供职业培训课程和资源,用户查看包括培训名称、类型、日期、老师、地点、点赞数等信息,可以进行报名、点赞、收藏、评价等操作,帮助用户提升就业竞争力和职业技能。
  5. 个人中心:用户可以登录个人账号,在个人中心查看和管理个人信息。可以修改个人资料、查看就业状态、上传个人作品等。
  6. 学生档案:用户可以查看自己的学生档案,包括个人信息、专业、是否毕业、最终学历、毕业日期、校内情况等。这些档案可以为用户的就业和学习提供参考和支持。
  7. 申请发放证书:用户可以通过系统申请发放相关证书,如毕业证书、培训证书等。
  8. 报名参加:用户可以报名参加系统中提供的职业培训、就业指导等活动。他们可以选择感兴趣的活动,并填写相应的报名信息,在报名参加中查看报名的信息。
  9. 报名回复:管理员可以查看用户的报名信息,并及时回复确认或提供进一步指导,用户在报名回复中查看管理员的审核回复。
  10. 收藏:用户可以将感兴趣的帖子、资源或课程收藏起来,方便以后查看和学习。

管理员端:

  1. 系统用户管理:管理员可以管理系统用户的注册、权限分配和账号信息。他们可以添加、删除或编辑普通用户和其他管理员的账号,并设置对应的权限。
  2. 学生档案管理:管理员可以管理学生档案的录入、查询和更新。可以记录学生的个人信息、专业、是否毕业、最终学历、毕业日期、校内情况等,并确保档案信息的准确性和安全性。
  3. 申请证书管理:管理员可以处理用户的证书申请。可以查看申请信息、审批申请并发放证书。
  4. 发放证书管理:管理员可以记录和管理已发放的证书信息,包括证书类型、颁发时间等。
  5. 职业培训管理:管理员可以管理系统中提供的职业培训课程和资源。可以添加、编辑和删除培训课程的信息,并设置相关的学习材料。
  6. 报名参加管理:管理员可以查看用户的报名信息,并进行审核和确认。
  7. 报名回复管理:管理员可以及时回复用户的报名信息,提供进一步指导和安排。
  8. 轮播图管理:管理员可以管理首页轮播图的内容和顺序。可以上传图片、添加文字说明,并设置轮播图的展示顺序,以便在首页上展示重要通知或宣传信息。
  9. 留言管理:管理员可以查看和回复用户的留言反馈。可以查看留言的内容、时间等信息,并及时回复用户,处理问题或提供帮助。
  10. 资源管理:管理员可以管理系统中的就业指导资源和分类。可以添加、编辑和删除资源,确保资源的准确性和多样性。
  11. 交流管理:管理员可以管理论坛中的帖子和评论。可以审查和监控帖子内容,保持论坛秩序和质量。
      1. 非功能性需求分析

毕业生档案管理系统的非功能性需求比如系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:

2.1 系统非功能需求表

安全性

主要指系统数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响系统占据市场的必要条件,所以性能最好要佳才好。

可扩展性

比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。

易用性

用户只要跟着系统的页面展示内容进行操作,就可以了。

可维护性

系统开发的可维护性是非常重要的,经过测试,可维护性没有问题

    1. 系统用例分析

毕业生档案管理系统中普通用户角色用例图如图2.1所示:

图2.1 用户角色用例图

毕业生档案管理系统中管理员用户角色用例图如图2.2所示:

图2.2 管理员角色用例图

系功能模块分成了管理员、普通用户两个模块,每个模块登录进去对应相应的功能,具体的功能模块图如图3.1所示。

   图3.1 毕业生档案管理系统功能模块图

    1. 数据库设计

数据库的设计承载者系统的各种数据,在建立数据库的时候,主要是数据库模型的设计以及各个数据库表的设计两部分。

      1. 数据库概念结构设计

下面是整个毕业生档案管理系统中主要的数据库表总E-R实体关系图。

图3.2 毕业生档案管理系统总E-R关系图

      1. 数据库逻辑结构设计

通过前面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

用户编号:

表article (文章:用于内容管理系统的文章)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

article_id

mediumint

8

0

N

Y

文章id:[0,8388607]

2

title

varchar

125

0

N

Y

标题:[0,125]用于文章和html的title标签中

3

type

varchar

64

0

N

N

0

文章分类:[0,1000]用来搜索指定类型的文章

4

hits

int

10

0

N

N

0

点击数:[0,1000000000]访问这篇文章的人次

5

praise_len

int

10

0

N

N

0

点赞数

6

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

7

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

8

source

varchar

255

0

Y

N

来源:[0,255]文章的出处

9

url

varchar

255

0

Y

N

来源地址:[0,255]用于跳转到发布该文章的网站

10

tag

varchar

255

0

Y

N

标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开

11

content

longtext

2147483647

0

Y

N

正文:文章的主体内容

12

img

varchar

255

0

Y

N

封面图

13

description

text

65535

0

Y

N

文章描述

表article_type (文章分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]决定分类显示的先后顺序

3

name

varchar

16

0

N

N

分类名称:[2,16]

4

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

5

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

6

icon

text

65535

0

Y

N

分类图标:

7

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

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

更新时间:

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

collect_id

int

10

0

N

Y

收藏ID:

2

user_id

int

10

0

N

N

0

收藏人ID:

3

source_table

varchar

255

0

Y

N

来源表:

4

source_field

varchar

255

0

Y

N

来源字段:

5

source_id

int

10

0

N

N

0

来源ID:

6

title

varchar

255

0

Y

N

标题:

7

img

varchar

255

0

Y

N

封面:

8

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

comment_id

int

10

0

N

Y

评论ID:

2

user_id

int

10

0

N

N

0

评论人ID:

3

reply_to_id

int

10

0

N

N

0

回复评论ID:空为0

4

content

longtext

2147483647

0

Y

N

内容:

5

nickname

varchar

255

0

Y

N

昵称:

6

avatar

varchar

255

0

Y

N

头像地址:[0,255]

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

9

source_table

varchar

255

0

Y

N

来源表:

10

source_field

varchar

255

0

Y

N

来源字段:

11

source_id

int

10

0

N

N

0

来源ID:

表forum (论坛)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

forum_id

mediumint

8

0

N

Y

论坛id

2

display

smallint

5

0

N

N

100

排序

3

user_id

mediumint

8

0

N

N

0

用户ID

4

nickname

varchar

16

0

Y

N

昵称:[0,16]

5

praise_len

int

10

0

Y

N

0

点赞数

6

hits

int

10

0

N

N

0

访问数

7

title

varchar

125

0

N

N

标题

8

keywords

varchar

125

0

Y

N

关键词

9

description

varchar

255

0

Y

N

描述

10

url

varchar

255

0

Y

N

来源地址

11

tag

varchar

255

0

Y

N

标签

12

img

text

65535

0

Y

N

封面图

13

content

longtext

2147483647

0

Y

N

正文

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

16

avatar

varchar

255

0

Y

N

发帖人头像:

17

type

varchar

64

0

N

N

0

论坛分类:[0,1000]用来搜索指定类型的论坛帖

表forum_type (论坛分类)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

type_id

smallint

5

0

N

Y

分类ID:[0,10000]

2

name

varchar

16

0

N

N

分类名称:[2,16]

3

description

varchar

255

0

Y

N

描述:[0,255]描述该分类的作用

4

url

varchar

255

0

Y

N

外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置

5

father_id

smallint

5

0

N

N

0

上级分类ID:[0,32767]

6

icon

varchar

255

0

Y

N

分类图标:

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表graduation_certificate (申请证书)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

graduation_certificate_id

int

10

0

N

Y

申请证书ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

student_major

varchar

64

0

Y

N

学生专业

5

final_education

varchar

64

0

Y

N

最终学历

6

id_number

varchar

64

0

Y

N

身份证号

7

application_date

date

10

0

Y

N

申请日期

8

mailing_address

varchar

64

0

Y

N

邮寄地址

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

hits_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

表issuing_certificates (发放证书)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

issuing_certificates_id

int

10

0

N

Y

发放证书ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

electronic_certificate

varchar

255

0

Y

N

电子证书

5

mailing_date

date

10

0

Y

N

邮寄日期

6

mailing_information

text

65535

0

Y

N

邮寄信息

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表message (留言板)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

message_id

int

10

0

N

Y

留言板ID:

2

user_id

int

10

0

N

N

0

用户ID:

3

title

varchar

64

0

Y

N

标题:

4

content

longtext

2147483647

0

N

N

内容:

5

nickname

varchar

32

0

N

N

昵称:

6

avatar

varchar

255

0

Y

N

头像:

7

email

varchar

125

0

Y

N

留言者邮箱

8

phone

varchar

11

0

Y

N

留言者手机号码

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

11

reply

longtext

2147483647

0

Y

N

回复

12

reply_state

tinyint

4

0

Y

N

0

回复状态

表praise (点赞)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

praise_id

int

10

0

N

Y

点赞ID:

2

user_id

int

10

0

N

N

0

点赞人:

3

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

status

bit

1

0

N

N

1

点赞状态:1为点赞,0已取消

表registration_reply (报名回复)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

registration_reply_id

int

10

0

N

Y

报名回复ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

reply_date

date

10

0

Y

N

回复日期

5

reply_to_message

text

65535

0

Y

N

回复信息

6

training_materials

varchar

255

0

Y

N

培训资料

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

regular_users_id

int

10

0

N

Y

普通用户ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_phone_number

varchar

64

0

Y

N

用户电话

4

user_address

varchar

64

0

Y

N

用户地址

5

examine_state

varchar

16

0

N

N

已通过

审核状态

6

user_id

int

10

0

N

N

0

用户ID

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表sensitive_vocabulary (敏感词汇)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

sensitive_vocabulary_id

int

10

0

N

Y

敏感词汇ID

2

sensitive_vocabulary

varchar

64

0

Y

N

敏感词汇

3

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

4

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表sign_up_to_participate (报名参加)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

sign_up_to_participate_id

int

10

0

N

Y

报名参加ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

user_address

varchar

64

0

Y

N

用户地址

6

registration_date

date

10

0

Y

N

报名日期

7

examine_state

varchar

16

0

N

N

未审核

审核状态

8

examine_reply

varchar

16

0

Y

N

审核回复

9

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表slides (轮播图)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

slides_id

int

10

0

N

Y

轮播图ID:

2

title

varchar

64

0

Y

N

标题:

3

content

varchar

255

0

Y

N

内容:

4

url

varchar

255

0

Y

N

链接:

5

img

varchar

255

0

Y

N

轮播图:

6

hits

int

10

0

N

N

0

点击量:

7

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表student_files (学生档案)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

student_files_id

int

10

0

N

Y

学生档案ID

2

regular_users

int

10

0

Y

N

0

普通用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

user_address

varchar

64

0

Y

N

用户地址

6

student_age

varchar

64

0

Y

N

学生年龄

7

student_major

varchar

64

0

Y

N

学生专业

8

graduated_or_not

varchar

64

0

Y

N

是否毕业

9

final_education

varchar

64

0

Y

N

最终学历

10

id_number

varchar

64

0

Y

N

身份证号

11

graduation_date

date

10

0

Y

N

毕业日期

12

on_campus_situation

text

65535

0

Y

N

校内情况

13

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

14

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表upload (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

upload_id

int

10

0

N

Y

上传ID

2

name

varchar

64

0

Y

N

文件名

3

path

varchar

255

0

Y

N

访问路径

4

file

varchar

255

0

Y

N

文件路径

5

display

varchar

255

0

Y

N

显示顺序

6

father_id

int

10

0

Y

N

0

父级ID

7

dir

varchar

255

0

Y

N

文件夹

8

type

varchar

32

0

Y

N

文件类型

表user (用户账户:用于保存用户登录信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

user_id

mediumint

8

0

N

Y

用户ID:[0,8388607]用户获取其他与用户相关的数据

2

state

smallint

5

0

N

N

1

账户状态:[0,10](1可用|2异常|3已冻结|4已注销)

3

user_group

varchar

32

0

Y

N

所在用户组:[0,32767]决定用户身份和权限

4

login_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

上次登录时间:

5

phone

varchar

11

0

Y

N

手机号码:[0,11]用户的手机号码,用于找回密码时或登录时

6

phone_state

smallint

5

0

N

N

0

手机认证:[0,1](0未认证|1审核中|2已认证)

7

username

varchar

16

0

N

N

用户名:[0,16]用户登录时所用的账户名称

8

nickname

varchar

16

0

Y

N

昵称:[0,16]

9

password

varchar

64

0

N

N

密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成

10

email

varchar

64

0

Y

N

邮箱:[0,64]用户的邮箱,用于找回密码时或登录时

11

email_state

smallint

5

0

N

N

0

邮箱认证:[0,1](0未认证|1审核中|2已认证)

12

avatar

varchar

255

0

Y

N

头像地址:[0,255]

13

open_id

varchar

255

0

Y

N

针对获取用户信息字段

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

表user_group (用户组:用于用户前端身份和鉴权)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

group_id

mediumint

8

0

N

Y

用户组ID:[0,8388607]

2

display

smallint

5

0

N

N

100

显示顺序:[0,1000]

3

name

varchar

16

0

N

N

名称:[0,16]

4

description

varchar

255

0

Y

N

描述:[0,255]描述该用户组的特点或权限范围

5

source_table

varchar

255

0

Y

N

来源表:

6

source_field

varchar

255

0

Y

N

来源字段:

7

source_id

int

10

0

N

N

0

来源ID:

8

register

smallint

5

0

Y

N

0

注册位置:

9

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

10

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间:

表vocational_training (职业培训)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

vocational_training_id

int

10

0

N

Y

职业培训ID

2

training_name

varchar

64

0

Y

N

培训名称

3

training_type

varchar

64

0

Y

N

培训类型

4

training_cover

varchar

255

0

Y

N

培训封面

5

training_date

date

10

0

Y

N

培训日期

6

training_teacher

varchar

64

0

Y

N

培训老师

7

training_location

varchar

64

0

Y

N

培训地点

8

training_introduction

text

65535

0

Y

N

培训简介

9

hits

int

10

0

N

N

0

点击数

10

praise_len

int

10

0

N

N

0

点赞数

11

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

12

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

管理员、用户在登录界面输入账号+密码,点击“登录”按钮,系统在用户数据库表中会对管理员、用户的账号进行匹配,账号+密码+完成验证正确的话,就会登录到系统中各个用户的主管理界面,否则提示对应的信息,返回到登录的界面,其主界面展示如下图4.1所示。

图4.1 登录界面图

登录代码:

def Login(self, ctx):

        print("===================登录=====================")

        ret = {

            "error": {

                "code": 70000,

                "message": "账户不存在",

            }

        }

        body = ctx.body

        password = md5hash(body["password"]) or ""

        obj = service_select("user").Get_obj(

            {"username": body["username"]}, {"like": False}

        )

        if obj:

            user_group = service_select("user_group").Get_obj({'name': obj['user_group']}, {"like": False})

            if user_group and user_group['source_table'] != '':

                user_obj = service_select(user_group['source_table']).Get_obj({"user_id": obj['user_id']},                                                                       {"like": False})

                if user_obj['examine_state'] == '未通过':

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "账户未通过审核",

                        }

                    }

                    return ret

                if user_obj['examine_state'] == '未审核':

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "账户未审核",

                        }

                    }

                    return ret

            if obj["state"] == 1:

                if obj["password"] == password:

                    timeout = timezone.now()

                    timestamp = int(time.mktime(timeout.timetuple())) * 1000

                    token = md5hash(str(obj["user_id"]) + "_" + str(timestamp))

                    ctx.request.session[token] = obj["user_id"]

                    service_select("access_token").Add(

                        {"token": token, "user_id": obj["user_id"]}

                    )

                    obj["token"] = token

                    ret = {

                        "result": {"obj": obj}

                    }

                else:

                    ret = {

                        "error": {

                            "code": 70000,

                            "message": "密码错误",

                        }

                    }

            else:

                ret = {

                    "error": {

                        "code": 70000,

                        "message": "用户账户不可用,请联系管理员",

                    }

                }

        return ctx.response(json.dumps(ret, ensure_ascii=False))

    1. 注册模块

注册模块满足用户两部分,当用户想要进行场地相关信息的查询管理的时候,就必须进行登录,如果没有账号的话,在登录界面,点击“注册”按钮就会跳转到注册的界面,根据提示填写好注册信息,添加提交,注册的信息在数据库中就添加完成了,然后再输入填写好的账号和密码进行登录,其主界面展示如下图4.2所示。

图4.2 注册界面图

注册代码:

def Register(self, ctx):

        print("===================注册=====================")

        userService = service_select("user")

        body = ctx.body

        if "username" not in body and body["username"] == '':

            return ctx.response(json.dumps({

                "error": {

                    "code": 70000,

                    "message": "用户名不能为空",

                }

            }, ensure_ascii=False))

        if "user_group" not in body and body["user_group"] == '':

            return ctx.response(json.dumps({

                "error": {

                    "code": 70000,

                    "message": "用户组不能为空",

                }

            }, ensure_ascii=False))

        if "password" not in body and body["password"] == '':

            return ctx.response(json.dumps({

                "error": {

                    "code": 70000,

                    "message": "密码不能为空",

                }

            }, ensure_ascii=False))

        post_param = body

        post_param['nickname'] = body["nickname"] or ""

        post_param['password'] = md5hash(body["password"])

        obj = userService.Get_obj({"username": post_param['username']}, {"like": False})

        if obj:

            return ctx.response(json.dumps({

                "error": {

                    "code": 70000,

                    "message": "用户名已存在",

                }

            }, ensure_ascii=False))

        ret = {

            "error": {

                "code": 70000,

                "message": "注册失败",

            }

        }

        bl = userService.Add(post_param)

        if bl:

            ret = {

                "result": {

                    "bl": True,

                    "message": "注册成功"

                }

            }

        return ctx.response(json.dumps(ret, ensure_ascii=False))

    1. 用户管理模块

管理员可以对系统中所有的用户角色进行管控,包含了管理员、普通用户两种角色,如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以查看到了,可以点击用户后面的“删除”按钮直接删除某一用户,普通用户由管理员统一添加,界面如下图所示。

图4.3 用户管理界面图

    1. 留言区模块

留言区:用户可以在留言区留下意见、建议或问题,并与管理员或其他用户进行交流和互动。界面如下图4.4所示。

图4.4 留言添加界面图

留言添加代码:

def Add(self, ctx):

body = ctx.body

unique = self.config.get("unique")

obj = None

if unique:

qy = {}

for i in range(len(unique)):

key = unique[i]

qy[key] = body.get(key)

obj = self.service.Get_obj(qy)

if not obj:

error = self.Add_before(ctx)

if error["code"]:

return {"error": error}

error = self.Events("add_before", ctx, None)

if error["code"]:

return {"error": error}

result = self.service.Add(body, self.config)

if self.service.error:

return {"error": self.service.error}

res = self.Add_after(ctx, result)

if res:

result = res

res = self.Events("add_after", ctx, result)

if res:

result = res

return {"result": result}

else:

return {"error": {"code": 10000, "message": "已存在"}}

    1. 就业指导模块

就业指导:提供就业指导资源,如职业规划、求职技巧、简历撰写等,帮助用户更好地进行就业准备和求职。界面如下图4.5所示。

图4.5 就业指导界面图

    1. 职业培训模块

职业培训:提供职业培训课程和资源,用户查看包括培训名称、类型、日期、老师、地点、点赞数等信息,可以进行报名、点赞、收藏、评价等操作,帮助用户提升就业竞争力和职业技能。界面如下图4.6所示。

图4.6 职业培训列表界面图

图4.7 职业培训报名界面图

管理员可以管理系统中提供的职业培训课程和资源。可以添加、编辑和删除培训课程的信息,并设置相关的学习材料。界面如下图4.8所示。

图4.8 职业培训添加界面图

    1. 学生档案模块

学生档案:用户可以查看自己的学生档案,包括个人信息、专业、是否毕业、最终学历、毕业日期、校内情况等。这些档案可以为用户的就业和学习提供参考和支持。界面如下图4.9所示。

图4.9学生档案界面图

    1. 申请证书模块

申请证书:用户可以通过系统申请发放相关证书,如毕业证书、培训证书等。界面如下图4.10所示。

图4.10申请证书界面图

    1. 发放证书模块

发放证书管理:管理员可以记录和管理已发放的证书信息,包括证书类型、颁发时间等。界面如下图4.10所示。

图4.11发放证书界面图

通过前面章节的介绍,我们可以看到本毕业生档案管理系统已经完成了,但是能不能投入使用还是未知,因为在每个项目正式使用之前必须对开发的项目进行测试,如果不进行测试一旦投入使用可能会出现很多未可知的问题,比如使用人数太多导致系统瘫痪,比如某一功能存在bug信息填写错误等,这些错误将给使用者带来很多的困扰,甚至造成更大的损失,因此测试是项目投入使用的最后一步,为用户提供一个运行顺畅、完美的项目也就是我们进行最后测试的目的。

    1. 系统部分测试

用户登录功能测试:

表5.1 用户登录功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

用户登录模块测试

用户登录成功的情况

点击前登录界面输入账号和密码分别输入admin和admin后点击“登录”按钮。

登录成功并调整到用户界面

正确

职业培训报名添加功能测试:

表5.2 职业培训报名添加功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

培训报名模块测试

培训报名成功的情况

在培训的页面中将点击添加,输入培训关信息,输入正确的信息后然后点击“提交”按钮。

提示添加成功

正确

培训报名模块测试

培训报名失败的情况

在培训页面中不填写的培训日期,其他信息正常输入“提交”按钮。

提示“添加失败,信息不能为空”

正确

查询就业指导功能模块测试:

表5.3 查询就业指导功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

查询就业指导功能测试

查询成功的情况

在就业指导界面输入资讯标题进行查询

查询成功

正确

申请证书功能测试:

表5.4 申请证书功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

申请证书模块测试

申请证书成功的情况

在申请证书信息的页面中将点击借阅,输入相关信息,输入正确的信息后然后点击“提交”按钮。

提示申请成功

正确

申请证书模块测试

申请证书失败的情况

在证书信息页面中不填写的申请日期,其他信息正常输入“提交”按钮。

提示“申请失败,信息不能为空”

正确

留言功能测试:

表5.4 留言功能测试表

测试名称

测试功能

操作过程

预期结果

测试结果

留言模块测试

留言成功的情况

在留言区的页面中将点击归还,输入相关信息,输入正确的信息后然后点击“提交”按钮。

提示留言成功

正确

留言模块测试

留言失败的情况

在留言区页面中不填写的留言信息,其他信息正常输入“提交”按钮。

提示“留言失败,信息不能为空”

正确

    1. 系统测试结果

通过编写毕业生档案管理系统的测试用例,已经检测完毕用户的登录模块、职业培训报名模块、查询就业指导、申请证书模块、留言模块的功能测试,在对以上功能得测试过程中,发现了系统中的很多漏送并进行了完善,经过多人在线进行测试,系统完全可以正常运行,当然在后期的维护中系统将不断完善。

  • 6 章 结论

在开发本毕业生档案管理系统之前我胸有成竹,觉得很简单,但在实际的开发中我发现了自身的很多问题,许多编程思想和方法都还没有掌握牢靠,比如Python 开发语言、Django框架,通过开发这个毕业生档案管理系统我成长了很多,懂得了做什么事情都要脚踏实地,不能眼高手低,在本次毕业生档案管理系统的开发中我逐渐掌握逐渐熟悉的技术。

本次毕业生档案管理系统的开发中我还学会了例如良好的编程思想和完善的规划思想。在着手编程之前需要罗列出程序框架的大概,脑海中构建出程序的主题框架。做好这一步我们才能胸有成竹的经行开发项目。当设计框架了熟于心之后,需要思考本次编程所需的主要知识点和技术点,并充分学习。

在本次项目中我也暴露了诸多问题。对于Python的编程知识有所欠缺,环境配置和算法上出现诸多问题,时常导致项目运行出错,或者目标的实现有问题。或者实现想法时算法未优化,使得代码冗长,程序运行不顺畅。

参考文献

[1]姚玲玲.新时期高校档案数字化转型发展研究[J].内蒙古财经大学学报,2023,21(06):130-132.

[2]魏晓玲,刘红英.基于Python和Django框架的琴房管理系统设计与实现[J].无线互联科技,2023,20(22):51-53.

[3]胡从寅,杨文远,赵鑫,许紫迎,杨哲,潘显鑫.基于Django+Vue.js的设计作品交易平台的实现[J].软件,2023,44(11):42-46.

[4]卫晨筱.高校学籍档案远程服务系统的构建及应用[J].现代职业教育,2023,(32):161-164.

[5]Sarah Hagelin.Shake my hand: Racial fantasies, white saviors, and Django Unchained's haunted screen[J].The Journal of Popular Culture,2023,56(5-6):781-796.

[6]曹伯强.基于云平台的高校师生电子健康档案管理系统的设计与应用[J].信息记录材料,2023,24(11):175-177.

[7]戴建成,王华,范玉婷.基于SpringBoot+VUE的高校廉政档案管理系统设计与实现[J].产业与科技论坛,2023,22(21):58-60.

[8]魏凯.基于Python Django框架的协同办公管理系统构建[J].信息与电脑(理论版),2023,35(16):114-116.

[9]秦梦杰.信息化背景下高校档案安全管理系统研究[J].办公室业务,2023,(15):108-110.

[10]高文静,王广胜.“互联网+”环境下高校教学档案管理系统优化升级研究与实践[J].办公室业务,2023,(13):128-131.

[11]Petropoulos Panagiotis,Zoulias Emmanouil,Liaskos Joseph,Mantas John.Web and Mobile Enabled Application for Public Health Inspections.[J].Studies in health technology and informatics,2023,305425-426.

[12]郭鹤楠.基于Django和Python技术的网站设计与实现[J].数字通信世界,2023,(06):60-62.

[13]李京.基于区块链的高校学籍档案管理系统研究[J].电脑知识与技术,2023,19(09):31-33+45.

[14]郑棉炜,陈旭杨,钟一凡,刘涛.基于Django的勤工俭学工资申报系统[J].网络安全技术与应用,2023,(02):37-39.

[15]盛娟.基于Web服务的高校人事档案信息分类管理系统研究[J].信息与电脑(理论版),2023,35(03):22-24.

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

[17]Yu Xiya,Li Xianhe,Wu Changping,Xu Gongyou.Design and Deployment of Django-based Housing Information Management System[J].Journal of Physics: Conference Series,2023,2425(1):

[18]华厚强,康佳春.基于Python的校园交易平台设计[J].现代计算机,2022,28(15):105-111.

[19]Li Hui chao,Shen Shun fa.Construction of College Students’ Physical Health Data Sharing System Based on Django Framework[J].Journal of Sensors,2021,2021

[20]Alnavar Kruthika,Kumar R Uday,Babu C Narendra.Document Parsing Tool for Language Translation and Web Crawling using Django REST Framework[J].Journal of Physics: Conference Series,2021,1962(1):

致谢

至此论文结束,感谢您的阅读。在此我要特别的感谢我的导师,虽然我在实习期间很忙,论文撰写的时候经常是停停改改,但是我的导师依旧十分的负责,时不时的询问我的任务进展情况,跟进我的论文进度,在指导老师的帮助下,我逐步完成了自己的论文和程序,从导师身上也学习到很多知识和经验,这些知识和经验令我受益匪浅。同时我也从导师身上看到了自己的不足,不论是在技术层面上还是在对待工作的态度上,导师如同明镜一般照出了我的缺点我的不足。此外,我还要感谢在我实习期间在论文和程序上帮助过我的同学和社会人士,此前我对于Django框架方面的一些知识还不了解,是他们在我编写程序过程中给了我很多的启发和感想,也帮助了我对于程序的调试和检测。没有他们我是不能顺利完成本次毕业设计的。至此,我的毕业设计就花上了一个圆满的句号了。

免费领取项目源码,请关注❥点赞收藏并私信博主,谢谢~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值