基于Struts2框架的名片管理系统

本文详述了一款使用Struts2框架构建的名片管理系统的开发过程,包括系统设计、数据库设计和功能实现。系统支持用户注册、登录、修改密码、管理名片等功能,数据库采用MySQL5.5,集成开发环境为Eclipse。主要功能模块有用户管理和名片管理,数据库设计包括用户信息表和名片信息表。此外,还介绍了系统的JAR包管理、JSP页面设计及异常处理。
摘要由CSDN通过智能技术生成

目录

1、系统设计

2、数据库设计

3、系统管理

4、用户管理

5、名片管理


本篇博文将分享一款基于Struts2框架的名片管理系统,JSP引擎为Tomcat9.0,数据库采用的是MySQL5.5,集成开发环境为Eclipse IDE for Java EE Developers。

名片管理系统主要包括用户管理和名片管理功能。用户功能主要包括:用户注册、用户登录、修改密码和修改基本信息功能;名片管理主要包括:添加名片、查询名片、修改名片、删除名片功能。

希望通过本篇的学习,朋友们不仅能掌握Struts 2应用开发的流程、方法和技术,还能够熟悉名片管理的业务需求、设计以及实现。

1、系统设计

1、系统功能需求

名片管理系统主要包含以下功能:

  • 非注册用户可以注册为注册用户;
  • 成功注册的用户,可以登录系统;
  • 成功登录的用户,可以添加、修改、删除以及浏览自己客户的名片信息;
  • 成功登录的用户,可以在个人中心查看自己的基本信息和修改密码。

2、系统模块划分

用户登录成功后,进入管理主页面(main.jsp)可以对自己的客户名片进行管理。系统模块划分,如下图所示。

名片管理系统功能

2、数据库设计

系统采用加载纯Java数据库驱动程序的方式连接MySQL5.5数据库。在MySQL5.5的数据库card中,共创建两张与系统相关的数据表:usertable和cardinfo。

1、数据库概念结构设计

根据系统设计与分析,可以设计出如下数据结构:

  • 用户

包括用户名和密码,注册用户名唯一。

  • 名片

包括ID、名称、电话、邮箱、单位、职务、地址、Logo以及所属用户。其中,ID唯一,“所属用户”与“1.用户”关联。根据以上的数据结构,结合数据库设计的特点,可画出如下图所示的数据库概念结构图。

数据库概念结构图

其中,ID为正整数,值是从1开始递增的序列。

2、数据库逻辑结构设计

将数据库概念结构图转换为MySQL数据库所支持的实际数据模型,即数据库的逻辑结构。用户信息表(usertable)的设计,如下表所示:

用户信息表

名片信息表(cardinfo)的设计,如下表所示:

名片信息表

3、系统管理

1、导入相关的jar包

新建一个Struts 2应用cardManage,在所有JSP页面中尽量使用EL表达式和JSTL标签,又因为系统采用纯Java数据库驱动程序连接MySQL5.5以及JSON数据转换。所以,需要将对应的JAR包复制到WebContent\WEB-INF\lib的目录下,JAR包如下图所示:

所需JAR包

2、JSP页面管理 

由于篇幅受限,这里仅附上运行效果图,所有实现见源代码。

  • 管理主页面

注册用户在浏览器地址栏中输入http://localhost:8080/struts2cardManage/login.jsp访问登录页面,登录成功后,进入管理主页面(main.jsp),main.jsp的运行效果如下图所示:

管理主页面

  • 程序报错页面

当Java程序运行出现异常时,系统会执行全局页面error.jsp。

  • 无权限提示页面

在没有成功登录的情况下,对名片进行增、删、改、查等操作时,系统执行无权限操作,提示页面nologin.jsp。

  • 包文件和配置文件管理

本系统的包文件和配置文件层次结构如下图所示:

包层次结构图

。。。。。。。。。。。。。。。。。

版权原因,完整文章,请参考如下:基于Struts2框架的名片管理系统

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一.功能简介 1. 实现一个图书管理系统。图书信息存放到一个数据库中。图书包含信息:图书号、图书名、作者、价格、备注字段。 2. 系统实现如下的基本管理功能: (1)用户分为两类:系统管理员,一般用户。 (2)提供用户注册和用户登录验证功能;其中登录用户的信息有:登录用户名,登录密码等。 (3)管理员可以实现对注册用户的管理(删除),并实现对图书的创建、查询、修改和删除等有关的操作。 (4)一般用户,只能查询图书,并进行借书、还书操作,每个用户最多借阅8本,即当目前借书已经是8本,则不能再借书了,只有还书后,才可以再借阅。 二.涉及技术 Struts2框架、MySQL数据库、C3P0数据池、Jsp、HTML、CSS、JavaScript等技术。 三.设计思路 1. 基于Struts2框架进行编程设计,连接MySQL数据库实现数据的增删查改,应用Jsp、HTML、CSS、JavaScript对访问页面进行编写和美化。 2. 分别创建book表和user表,用以存放图书信息和用户数据。其中user表中,设有flag以区分管理员和普通用户。 3. 分别创建Book类和User类,与数据表相对应。每本书和每个用户都有唯一的id与之对应。 4. 创建C3P0属性文件和数据库连接工具类。 5. 设计数据库操作类:UserDao类和BookDao类。UserDao用于实现所有对user表的操作,BookDao用于实现所有对book表的操作。 6. 创建分别对应UserDao类和BookDao类的Action:UserAction和BookAction。采用基于注解的方式进行Action配置。 7. 用户账号分为管理员账号和普通用户账号,注册时加以区分,登录时即可自动判断进入对应的操作主页面。 8. 管理员可实现对用户的查询显示,模糊查询,删除,批量删除,全选和取消全选等功能;可实现对图书的查询显示,模糊查询,添加,删除,批量删除,全选和取消全选等功能。 9. 普通用户可实现借书和还书功能,借书功能通过对book表的查询,将未借出的图书按照id顺序排列显示,点击表格后方的“借阅”按钮,进行确认借阅,将book表中本书的borrowperson列的值改为本用户账号。对于借阅成功的图书可以在“当前借阅”中进行查看。还书功能通过在“当前借阅”中点击“还书”按钮,进行确认还书,将book表中本书的borrowperson列的值改为“空”,本书信息将可以在“借书”界面查看。 四.存在的问题 1. 原本希望能为每一个用户创建一个对应的以其账号命名的数据表,用以存放用户所借图书信息,但创建表的SQL语句无法在java代码中执行,所以只好在book表中添加一列borrowperson,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“where borrowperson=‘account’”为条件对book表进行查询即可。但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。 2. 模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询,查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。这种方法虽然实现了查询,但效率太低,代码过于繁重。 五.改进预想 这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。 1. 希望实现登录时验证码验证登录; 2. 希望实现查询时,查询结果分页浏览; 3. 进一步优化Action之间的传值方法; 4. 页面进一步优化、美化; 5. 实现用户借书还书时间记录,和借阅时长限制。
第五章基于struts2名片管理系统主要介绍了如何使用struts2框架来开发一个名片管理系统名片管理系统用于记录和管理个人名片的相关信息,包括姓名、职位、联系方式等。 在这一章中,我们首先介绍了struts2框架的基本概念和架构。struts2是一个基于MVC设计模式的开源框架,它将请求、处理和响应分别交给Action、Interceptors和Result来处理,从而实现了请求的分发和处理。 接着,我们详细介绍了如何使用struts2框架来实现名片管理系统的各个功能。首先,我们创建了一个名片Action类,用于处理名片相关的请求。通过配置struts.xml文件,我们将名片Action与相应的URL路径进行映射,以便正确地分发请求。 在名片Action中,我们定义了各种方法来处理不同类型的请求,如查询名片、添加名片、更新名片等。通过在方法中使用struts2框架提供的注解和标签,我们可以很方便地获取和处理请求参数,然后进行相应的业务逻辑操作。 除了Action类之外,我们还介绍了如何使用struts2提供的标签来简化前端页面的开发。通过使用struts2的标签,我们可以方便地将Java对象和HTML表单进行绑定,从而实现数据的传递和显示。 最后,我们还介绍了如何使用struts2提供的验证器和拦截器来增强名片管理系统的安全性和可靠性。通过配置拦截器,我们可以在请求到达Action之前进行一些操作,如身份验证、日志记录等。 总之,第五章基于struts2名片管理系统详细介绍了如何使用struts2框架开发一个完整的名片管理系统,通过学习这一章的内容,读者可以掌握使用struts2框架开发Web应用的基本方法和技巧。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值