慧与(洛阳)国际软件人才及产业基地
《员工管理系统》课程设计报告
EPM管理系统
小组成员: 杨智浩
李贝西 常 杰 程君侠 李 宁 高凌月
任课教师:李腾昊
2016年6月12日
III
目录
第一章 绪论 ....................................................... 1
1.1背景及意义 ........................................................................................................................ 1
1.2 课题研究意义 ................................................................................................................... 1 1.3 小组分工 ........................................................................................................................... 1 1.4论文组织 ............................................................................................................................ 2
第二章 系统应用技术 ............................................... 3
2.1 应用技术及开发环境介绍 ............................................................................................... 3 2.2 数据库连接 ....................................................................................................................... 3
2.2.1 连接MySQL数据库时的驱动器: ...................................................................... 3 2.3 EasyUI插件集合 .............................................................................................................. 3
第三章 需求分析 ................................................... 4
3.1 概要分析 ........................................................................................................................... 4 3.2 具体分析 ........................................................................................................................... 5
3.2.1 用户登录用例 ....................................................................................................... 5 3.2.2 项目组 ................................................................................................................... 6 3.2.3 公告信息 ............................................................................................................... 7 3.2.4 员工信息 ............................................................................................................... 7
第四章 设计和实现 ................................................. 9
4.1登录与主页面 .................................................................................................................... 9 4.2 项目组信息管理模块 ................................................................................................. 11
4.2.1 增加项目组 ..................................................................................................... 12 4.2.2 修改项目组 ..................................................................................................... 15 4.2.3 删除项目组 ..................................................................................................... 17 4.2.4 查询项目组 ..................................................................................................... 19 4.3公告信息管理模块 .......................................................................................................... 23
4.3.1 查询公告 ............................................................................................................. 23 4.3.2 删除公告 ............................................................................................................. 25 4.3.3 增加公告 ............................................................................................................. 27 4.3.4 修改公告 ......................................................................................................... 30 4.4员工信息管理模块 .......................................................................................................... 32
4.4.1 查询员工信息 ..................................................................................................... 32 4.4.2 删除员工信息 ..................................................................................................... 35 4.4.3 增加员工信息 ..................................................................................................... 36 4.4.4 修改员工信息 ..................................................................................................... 40
第五章 结论与展望 ................................................ 41
5.1 结论 ................................................................................................................................. 42 5.2 展望 ................................................................................................................................. 43
参考文献 ......................................................... 44 致 谢 ........................................................... 45
IV
1.1背景及意义
第一章 绪论
现代信息技术的发展,在改变着我们的生活方式的同时,也改变着我们的工作方式,使传统意义上的企业员工管理的形式和内涵都在发生着根本性的变化。企业员工信息管理的内容也已经转变为对更为广泛的系统价值的追求。信息管理,如今已是一个热门话题,它已为许多企业所采用。在现代化的进程中,引入现代管理的思想,建立一套可面向企业单位的员工信息管理系统,也是十分必要的。
本课题基于我国企业管理信息化建设现状,结合在实际工作中所遇到的问题和收获,对企业员工管理系统在开发等方面进行研究,重点研究系统开发过程中所采用的软硬件平台规范、数据库结构设计、开发工具的选择与使用,目的是从技术手段的角度阐述如何实现企业从传统经营管理模式向信息化管理模式转变的过程,以及企业员工管理系统在企业管理信息化中所起到的重要作用。
1.2 课题研究意义
目前,在国内外各大企业中,企业员工信息管理系统的使用是非常广泛的。同时,有很多的软件开发商也开发了许多基于各种行业的企业员工管理学系统。而不同的企业具有不同的企业员工管理制度,这就决定了不同的企业需要不同的企业员工管理系统。而且,企业管理信息量大、操作繁琐、传统的方式不再使用新的工作需要,开发研制适合企业的企业员工管理系统,使其具有整体性强、流程简单、操作方便、功能丰富和通用性强等特点,是加快企业人才管理工作办公自动化、信息资源化和管理科学化建设进程必要途径。因此建立适合企业的管理信息系统,是促进企业信息高速公路的发展,为企业发展提供条件的重要课题。如何建立一个精简、有效的企业信息管理体系,企业信息管理信息系统,如何有效支持企业项目管理体系,从而提高企业的项目管理能力,是具有非常重大的实际应用意义的。
1.3 小组分工
在系统的实际开发中,高凌月、王星月同学主要负责了登录模块与系统主页面的编写工作。在编写过程中,使用cookie实现了登录时记住密码的功能。使用session解决了过滤未登录时进行的操作。程君侠同学负责编写项目组模块,
1
李宁同学负责编写公告信息模块,常杰、李贝西同学负责编写员工信息管理模块。在编写过程中,4人都使用了StringBuffer线程安全的加载数据库SQL语句。建立了JsonUtil工具包,将ResultSet结果集转换为了JSON数组的形式,加载到了dategrid数据表格中。在涉及到Date类型与String类型的转换中,建立了DateUtil工具包,将两种类型的数据进行转换,存入数据库中。
1.4论文组织
论文的组织结构如下:
第一章绪论,主要介绍了系统的开发背景与意义,小组的分工情况。 第二章系统应用技术,主要介绍了系统的开发环境,所使用的开发技术等。 第三章需求分析,描述了系统的开发需求,包括登录模块与主页面,项目组信息管理模块,公告信息管理模块,员工信息管理模块。
第四章设计与实现,具体描述系统各模块的设计思路与实现方法。 第五章结论与展望,总结了在设计与实现过程中的一些问题与解决方法,和对此次课程设计的收获与感悟。
2
第二章 系统应用技术
2.1 应用技术及开发环境介绍
该系统使用eclipse集成开发环境,应用Java程序设计语言进行编程,在eclipse开发工具中进行开发。该系统的开发时采用MVC设计模式,由前台页面与数据库连接实现系统中数据的增删改查,该系统主要包括登录、项目组管理,员工信息管理,公告信息管理等功能模块。
主要用到的技术:基于jQUery的UI插件集合EasyUI,数据库使用了MySql,并且使用了Navicat实现数据库的可视化操作,数据库连接时所需要的驱动器。
运行环境:该系统以jdk1.6 版本 JDK为Java运行环境。
2.2 数据库连接
驱动器的加载:系统中对大量数据的增删改查时需要连接数据库,从数据库中取出所需要的信息,连接不同的数据库需要加载的驱动器不同
2.2.1 连接MySQL数据库时的驱动器:
mysql-connector-java-5.0.8-bin.jar(驱动器jar包) 加载驱动以及连接数据库语句代码如下: Class.forName(“com.mysql.jdbc.Driver”); Mysql的应用有以下特点:
1. 小型关系型数据库管理系统 2. 语言简洁,易学易用 3. 适应于所有的平台
4. .是开源软件,版本更新较快
5. 全面支持SQL的GROUP BY和ORDER BY子句,支持聚合函数
2.3 EasyUI插件集合
EasyUI的应用有以下特点: 1. 简单,但很强大
2. 开发产品时可节省时间和资源
3. 支持扩展,可根据自己的需求扩展控件
4. 为一些当前用于交互的js应用提供必要的功能 5. 丰富并且美观的UI界面
3
第三章 需求分析
3.1 概要分析
3.1.1用例描述
功能类别 项目组信息管理 功能名称 增加 删除 修改 查询 员工信息管理 增加 删除 修改 查询 公告信息管理 增加 删除 修改 查询 添加一个新的项目组 删除一个项目组信息 修改一个项目组信息 查询一个项目组信息 添加一个新的员工信息 删除一个员工信息 修改一个员工的基本信息 查询一个员工的基本信息 发布一条新的公告 删除一条公告 修改一条公告 查询发出的公告 描述
4
3.1.2用例图
3.2 具体分析
3.2.1 用户登录用例
3.2.1.1 用例图
3.2.1.2 用例描述
描述要素
用例名称 描述内容 用户登录 用户输入帐号与密码进行登录 管理员 用户登录 5
备注事项
用例简述 参与者 前置条件 后置条件 3.2.1.3 事件流
用户登录页面
2.输入账号和密码() 1.打开登录页面()
4.提示登录结果() 3.验证()
3.2.2 项目组
3.2.2.1 用例图
3.2.2.2 用例描述 描述要素 用例名称 用例简述 参与者 前置条件 后置条件
描述内容 项目组信息管理 用户可以管项目组的名称 用户 用户必须登录 用户必须登录成功 备注事项 6
3.2.3 公告信息
3.2.3.1 用例图
3.2.3.2 用例描述 描述要素 用例名称 参与者 前置条件 特殊需求
描述内容 EPM员工管理系统公告模块 管理员 管理员必须先登录 无 3.2.4 员工信息
3.2.4.1 用例图
7
3.2.4.2 用例描述
描述要素 用例名称 用例简述 参与者 前置条件 后置条件
描述内容 员工信息管理 管理员对员工信息维护 管理员 管理员必须先登录且有员工信息管理权限 管理员对员工信息的管理可能会影响到员工的信息改变,管理员通过学号、姓名、出生日期,和性别等方式,查询员工信息。
8
第四章 设计和实现
4.1登录与主页面
4.1.1 与数据库连接
public User login(Connection con,User user)throws Exception{
User resultUser=null;
String sql=\"select * from user where username=? and password=?\";
PreparedStatement pstmp=con.prepareStatement(sql); pstmp.setString(1, user.getUsername()); pstmp.setString(2, user.getPassword()); ResultSet rs=pstmp.executeQuery(); while(rs.next()){ resultUser=new User();
resultUser.setUsername(rs.getString(\"username\")); resultUser.setPassword(rs.getString(\"password\")); }
return resultUser; }
}
4.1.2登录
首先jsp界面将管理员账号密码提交到登录的servlet,在servlet中接收账号密码进行判断,如果为空,转发回登录界面并提示;不为空,连接数据库进行查询,如果未找到返回为空对象,转发回登录界面并提示账号密码错误;如果找到返回一个user对象,接下来判断保存账号密码的复选框是否勾选,如果未勾选直接在session中保存user对象,重定向到首界面;如果勾选获取账号密码,放入cookie对象中,设置cookie生命时间,存入response中,然后session中保存user对象,重定向到首界面。
String autoLogin = req.getParameter(\"autoLogin\");//获取是否选择了保存信息 UserDao ud = new UserDao();
//链接数据库查询,返回User对象
User user = ud.getLogin(username, password); //如果User对象不为空
if(user!=null&&user.getName()!=null){
//勾选了保存信息
if(autoLogin!=null){
//创建Cookie
Cookie cookie1 = new Cookie(\"username\", username); Cookie cookie2 = new Cookie(\"userpwd\", password); //设置Cookie时间
9
cookie1.setMaxAge(60*60*24*365*10000); cookie2.setMaxAge(60*60*24*365*10000);
//保存Cookie
resp.addCookie(cookie1); resp.addCookie(cookie2); }
//登陆信息正确,将User对象保存在session;重定向到主界面 session.setAttribute(\"loginuser\", user); resp.sendRedirect(\"index.jsp\"); }else{
//信息验证失败,弹出提示框,重定向到登陆界面
out.println(\"\");
resp.setHeader(\"refresh\",\"0;URL=login.jsp\");
}
4.1.3 过滤器
限制主界面,过滤器doFilter中获取session(HttpSession session =
req.getSession();)从session获取储存的user对象,看是否为空,为空不能继续访问,重定向到登录界面,不为空可以继续访问
if(session.getAttribute(\"loginuser\")!=null){ chain.doFilter(request, response); }else{
res.sendRedirect(\"login.jsp\");
}
4.1.4登录界面
遍历cookie获取name和pwd放到输入框value中 <%
String name = \"\"; String pwd=\"\";
Cookie[] cookies = request.getCookies(); if(cookies!=null){
for(Cookie cookie:cookies){
if(cookie.getName().equals(\"username\")){ name = cookie.getValue(); }
if(cookie.getName().equals(\"userpwd\")){ pwd = cookie.getValue(); } } } %>
10
4.2 项目组信息管理模块
在数据库中建立t_group表
在model包里创建Group类
代码如下
11
然后再在Dao包里面创建GroupDao类,代码如下
4.2.1 增加项目组
4.2.1.1添加信息的流程图:
4.2.1.2 首先是jsp页面的建立,几个按钮和查询框的代码如下
12
4.2.1.3点击增加按钮后通过调用页面中的js函数openAddGroup()弹出填写增加公告内容的表单,如下图所示: 调用函数:
4.2.1.4 添加弹出的窗口代码如下:
13
4.2.1.5.servlet获取到前台的删除条数,把参数转换成json数据传到groupdao的删除方法中实现数据的传递功能;并进行判断数据是否删除成功,反馈到前台通知用户是否操作成功
4.2.1.6 然后调用GroupDao里的GroupAdd方法
14
4.2.2 修改项目组
4.2.2.1修改项目组流程图:
4.2.2.2前端jsp页面
15
4.2.2.3 servlet和前台紧密相连,前台的提交和数据的读取都需要它的支持;
4.2.2.4GroupDao执行中心,数据与数据库的交互执行,修改数据传到数据库中
16
4.2.2.5 Group是数据值交互的中心,他负责中整个字段的数据传递和获取
4.2.3 删除项目组
4.2.3.1删除项目组信息流程图
17
4.2.3.2首先在前台通过Javascript获取要被删除的信息,在script在Ajax更好的获取要删除的信息并进行简单的询问认证以防在不名的情况下删除信息;
4.2.3.3 servlet获取到前台的删除条数,把参数转换成json数据传到groupdao的删除方法中实现数据的传递功能;并进行判断数据是否删除成功,反馈到前台通知用户是否操作成功
18
4.2.3.4 把在servlet中传递的参数进入groupDao类中写删除语句,对
数据库进行操作
4.2.4 查询项目组
4.2.4.1查询信息的流程图
19
4.2.4.2通过servlet对数据库进行查询的操作,request获取页面数据;if语句把null转换为String的空字符,调用groupdao对数据库进行语句查询:
20
4.2.4.3 用group类中的get 和 set 方法获取值和传递值: 在类重写构造方法使之更加实用与我们的调用;
21
4.2.4.4groupDao是对数据库查询的关键,在这里有查询方法和分页设计: 用StringBuffer对象保存数据查询语句的公共部分,调用append方法添加具体的查询方法,这样节省代码的复杂性,使功能具有易维护性;
4.2.2.5对查询结果进行分页:
22
4.3公告信息管理模块
4.3.1 查询公告
23
NoticeServlet里面通过Result rs=noticeDao.noticeList(con,pageBean,notice);调用NoticeDao里面的noticeList方法,实现对公告的遍历;
通过int total=noticeDao.noticeCount(con, notice);来调用NoticeDao里面的 getConnt方法,通过判断,若搜索栏里面的内容为空,则查询所有公告的
条数,若搜索栏里面的公告名字不为空,则以模糊查询的方式查询相应的公告, 若搜索栏里面的发布人名字不为空,则以模糊查询的方式查询相应的公告, 若搜索栏里面的查询公告的起始日期,终止日期不为空,同样以模糊查询的方式查询相应的公告
24
4.3.2 删除公告
4.3.2.1删除公告流程图:
如下图所示:
图4-4-4.2
25
4.3.2.2点击修改按钮后调用noticeDelect()先判断是否选择了一条数据或多条数据,并把选中的公告id传送到相对应的servlet页面:
图4-4-4.3
4.3.2.3在向servlet中传输选中id是需要把页面的Object类型准换位String类型的 如下:
4.3.2.4在servlet中进行验证,并把验证结果返回到jsp页面,并提示删除成功或删除失败:
26
4.3.2.5在servlet中获取到Id后通过调用NoticeDao中的noticeDelete()方法来实现删除:
4.3.3 增加公告
4.3.3.1增加信息的流程图:
4.3.3.2 首先是jsp页面的建立,几个按钮和查询框的代码如下:
27
4.3.3.3点击增加按钮后通过调用页面中的js函数openAddnotice()弹出填写增加公告内容的表单,如下图所示: 调用函数:
4.3.3.4弹出表单代码如下:
28
当表单填写完成后点击确定时,调用JavaScript函数saveGroup方法进验证验证:
4.3.3.5通过函数跳转到servlet页面,servlet页面通过传递过来的值进行验证添加是否成功,并在页面提示添加是否成功。Servlet如下:
4.3.3.6然后调用NoticeDao里面的noticeAdd方法
29
4.3.3.7添加时需要用到DateUtil来进行时间的格式转换内容如下:
4.3.4 修改公告
4.3.4.1修改公告流程图:
30
4.3.4.2点击修改按钮后调用openUpdateNotice()先判断是否选择了一条数据,当多选或不选时报错,当只选中一条时弹出修改表单并把选中的公告id传送到相对应的servlet页面:
图4-4-3.2
4.3.4.3填写内容后点击确认按钮调用saveGroup()验证:
4.3.4.4通过saveGroup()提交到修改的servlet页面进行处理,并在页面提示相应的修改成功或失败的提示,修改的servlet如下:
31
4.3.4.5 在servlet中获取到Id后通过ID把从页面获取到修改表单中数据通过调用NoticeDao中的noticeUpdate()方法修改到数据库中:
4.4员工信息管理模块
4.4.1 查询员工信息
本系统查询员工信息,有5种方式,即按学号查询、名称查询、性别查询、出生日期查询、项目组查询,分别在定义5个查询不同的参数。首先通过JSP页面获取查询的参数,通过URL将值传到StudentListServlet中,通过Request获取从页面中传来的参数,把获取的参数保存在一个新的Student对象中,调用StudentDao中的StudentList方法,List首先判断查询参数是否为空,如果不为空,执行相应的SQL语句,返回结果给Servlet,Servlet得到返回结果,进行判断操作是否成功,将判断结果通过JSON返到JSP页面,页面打印输出结果。
4.4.1.1studentIntoManager中的searchStudent:
32
4.4.1.2页面显示的搜索框代码:
4.4.1.3 Servlet中的查询方法:
4.4.1.4将日期格式转换为字符型:
33
4.4.1.5 StudentDao中的查询:
4.4.1.6查询结果分页:
4.4.1.7在页面中显示查询结果:
34
4.4.2 删除员工信息
删除公告的前提是获取操作对象的ID,通过dg的ID获取datagrid,得到变量值后,判断是否为空,如果为空提示用户至少选择一条数据进行删除,同样通过JSON根据URL的地址将值传到servlet中,Servlet再调用StudentDao中的DeleteStudent操作,执行删除操作,结果先返回给了Servlet,通过JSON的result,判断结果返回给了Jsp中的DeleteStudent(),根据返回结果进行相应的处理。 关键代码:
4.4.2.1页面获取id:
4.4.2.2 Servlet中的删除方法:
35
4.4.2.3 在页面中显示删除状态:
4.4.3 增加员工信息
4.4.3.1增加信息的流程图:
36
在studentInfoManager.jsp页面script的function中AddStudent()方法。在body中写入一个新的div,包含两部分,即对话框和保存按钮,这个div是默认隐藏的,只有调用时候才显示AddStudent()调用页面中隐藏的对话框。saveStudent()获取对话框中的值,再由保存按钮把值保存,通过给定URL的参数,再由把数据传到Servlet中。
4.4.3.2 AddStudent()
4.4.3.3 打开对话框,输入数据:
4.4.3.4保存数据,并提交到Servlet中:
37
4.4.3.5 Servlet中的实现添加的方法。
用request获取从页面传来的数据,实例化一个Student对象保存参数,判断是否含有id,员工的id在数据库自动生成,所以执行添加操作不需要id,调用StudentDao中的StudentAdder方法,添加成功后,影响行数大于0,判断返回值是否大于0,如果大于0,则JSON实例化对象result调用put方法,把success的值为true,否则errorMsg的值为“添加失败”。部分代码如下:
4.4.3.6 JSON的代码:
4.4.3.7 StudentDao中的添加方法:
38
4.4.3.8获取项目组名称:
4.4.3.9页面显示添加状态
添加完成后,studentInfoManager.jsp通过success:function
(result)获取Servlet中JSON中的result的参数,判断添加是否成功,如果成功,显示保存成功,并局部刷新界面。部分代码如下:
39
4.4.4 修改员工信息
在StudentinfoManager.jsp界面中,点击修改按钮,通过href标签进入openUpdateStudent()方法,判断复选框的值是否为1,修改数据条数有且仅有1条。与添加不同的是,修改数据需要id,id是从selectedRows中获取。条件成立,调用页面中隐藏的对话框,通过选中的数据把待修改内容输出在对话框中,修改完成后,openUpdateStudent()调用saveStudent方法,获取对话框中的值,再由保存按钮把值提交,通过给定URL的参数,再由把数据传到Servlet中。
4.4.4.1 openUpdateStudent()
4.4.4.2 打开对话框,输入修改信息
40
4.4.4.3 JSONObject:
4.4.4.4 UpdateStudent:
4.4.4.5 修改学生信息显示
41
第五章 结论与展望
5.1 结论
通过半个月的项目实战,让我获益匪浅,不仅更深入的了解Java这门学科,更使自己有了继续探索的兴趣。虽然制作的亿源科技EMP管理系统在功能上能够满足要求,但是也有很多不足的地方。通过对程序的不断调试与完善,所有功能均可实现,所设计系统已基本达到了设计要求,主要实现了用户登录功能,实现了对项目组信息,学生信息,公告信息的分页显示,对项目组信息的增、删、改、查等基本功能,实现了对学生信息以及公告信息的增、删、改、查等基本功能,项目组的查询可根据项目组名称,项目组描述等,学生信息的查询可根据学生的学号,姓名,出生日期,性别,以及所在项目组编号等,公告信息的查询可根据公告的标题,发布人,以及发布时间等基本达到了预期设想
在本次项目中, 在eclipse中运行,初步纠错并实现。系统采用了EasyUI中的一些控件,使代码量减少, 同时采用MVC模式,首先定义一些实体类是编写程序设计的第一步,它关系到下面对项目组信息,学生信息,公告信息的增、删、改、查等基本功能的实现,尤为重要。亿源科技EMP管理系统必然包括项目组管理,学生管理,公告管理三个模块,三个模块分别包括Group,Notice,Student三个实体类;然后创建Dao类,实现与数据库的连接,对项目组信息,学生信息,公告信息进行增删改查。分别写出项目组管理,学生管理,公告管理增加,删除,修改,查询相对应的servlet,将从数据库中取出的数据转成JSON数据显示在jsp页面中。在做项目的过程中,我深感“认真严谨”这个词的重要性,一点点小的马虎,便会导致整个程序不能正常运行。在今后的学习中,我定将“认真严谨”时刻作为自的谨言。与此同时,本小组成员的互帮互助,让我体会到了团结的力量,而更让人难以忘怀的是在热烈讨论问题时,那激情横溢的场面。
我觉得能多做几次项目是十分有意义而且是十分必要的。在之前的学习中我们大多数接触的是专业基础课。我们在课堂上掌握的仅仅是专业基础课的理论面如何去锻炼我们的实践面如何把我们所学到的专业基础理论知识用到实践中去呢,我想做类似的项目就为我们提供了良好的实践平台。在做本次项目的过程中,为了让自己的设计更加完善,更加符合软件工程标准一次次翻阅各种参考资料是十分必要的同时也是必不可少的。我们是在作设计,但我们不是艺术家。他们可以抛开实际,尽情在幻想的世界里翱翔,我们是软件设计师,一切都要有据可依.有理可寻,不切实际的构想永远只能是构想,永远无法升级为设计。作为一名学生掌握一门或几门程序设计语言是必不可少的。在这次的项目实战中不仅检验了我们所学的知识,也培养了如何去把握一件事,如何完成一件事,与同学分工设计,和同学们相互探讨,相互学习,相互监督,学习了知识,学会了合作。这个项目是我们专业课程知识综合应用的实践训练,是我们迈向社会,从事职业必不可少的过程,此次项目实战不仅学习了新知识,采用JSON数据将结果显示到页面上,同时也对Ajax进行巩固,对以前所学的一些知识进行了复习。
42
5.2 展望
对于我们这种还未毕业,没有任何工作经验学生来说首要目标就是掌握好基础知识,然后多接触一些项目,增加自己的经验,提高自己的能力。增强自学能力,拓宽自己的知识面,为毕业后找工作打基础。寻求一份适合自己的工作,踏踏实实做好现在的事就是对未来最好的准备,努力做好这个项目对自身以及整个小组有要求,这样付出的时间和精力才有价值,对日后工作同样有所帮助首先要提高自己的技术水平,虽然现在所做的东西和真正的项目相比实在是不值一提,但是对学生掌握基础知识很有帮助,只有加强团队合作,组员默契配合,合力达成目标,才能做到高效率高质量,一件事情的完成需要付出足够的努力和耐心,成熟起来成长起来。
然后是要锻炼自己与人交流以及团队合作的能力,世界上没有完全相同的两片叶子,当然也不存在没有差异的两个人,在一个集体中工作与生活,永远避免不了与别人发生矛盾或者是一起合作,所以说与人交流很重要,可以减少很多矛盾的发生以及避免已经发生的矛盾恶化。
43
参考文献
[1] XXXXX
44
致 谢
45
因篇幅问题不能全部显示,请点此查看更多更全内容