一.功能简介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,用来存放借阅本书的用户账号,这样查询用户当前借阅记录时,以“whereborrowperson=‘account’”为条件对book表进行查询即可。
但是每个用户要当前查询借阅记录时都需要对整个book表进行遍历,效率太低。
2.模糊查询时,因同时需要进行where筛选,SQL语句无法执行,只好分开查询,先进行模糊查询,查询结果存放到list表中,再通过遍历list表进行判断是否符合where的条件,若符合,则存入另一个list表中。
这种方法虽然实现了查询,但效率太低,代码过于繁重。
五.改进预想这些本不应该是预想,原本希望在本次作业中实现的,但时间不够充分,只能作为下一步的改建预想。
1.希望实现登录时验证码验证登录;
2.希望实现查询时,查询结果分页浏览;
3.进一步优化Action之间的传值方法;
4.页面进一步优化、美化;
5.实现用户借书还书时间记录,和借阅时长限制。
2025/7/20 9:38:38 13.98MB Struts2
1
亚马逊超级畅销书,雄踞排行榜数年之久!原谷歌资深面试官的经验之作,层层紧扣程序员面试的每一个环节,全面而详尽地介绍了程序员应当如何应对面试,才能在面试中脱颖而出。
第1~7章主要涉及面试流程解析、面试官的幕后决策及可能提出的问题、面试前的准备工作、对面试结果的处理等内容;
第8~9章从数据结构、概念与算法、知识类问题和附加面试题4个方面,为读者呈现了出自微软、苹果、谷歌等多家知名公司的150道编程面试题,并针对每一道面试题目,分别给出了详细的解决方案。
2025/7/20 5:44:54 53.81MB 面试宝典 最新版
1
我是大三的计算机系的,自己花了一天的时间做的一个数独小程序,有源代码,希望对学习编程的朋友有用
2025/7/19 12:45:30 14KB vb数独 数独程序 数独源代码
1
my_socket是将文件从windows传输到linux,my_socket_verify是将linux下的文件传到windows(因为我只写了单向的,verify只是做了一个验证而已)
2025/7/19 11:45:18 68KB socket编程 数据传输
1
**VSCodeSetup-x64-1.19.1安装软件及详细配置**VisualStudioCode(简称VSCode)是Microsoft开发的一款免费、开源的源代码编辑器,支持多种编程语言,适用于Windows、macOS和Linux操作系统。
版本1.19.1是VSCode的一个历史版本,尽管当前可能已有更新版本,但理解这个版本的安装和配置过程对于学习VSCode的基本操作仍然是有益的。
1.**下载与安装**-下载:你需要从Microsoft的官方网站或通过提供的压缩包文件下载VSCodeSetup-x64-1.19.1安装程序。
该文件适用于64位Windows系统。
-安装:双击下载的安装程序,按照向导提示进行安装。
通常,你可以选择默认设置,但也可以自定义安装路径、是否创建桌面快捷方式等选项。
2.**首次启动与界面**-启动:安装完成后,启动VSCode,你会看到简洁的用户界面,包括左侧的资源管理器、中间的编辑区域和右侧的终端或输出窗口。
-主题:VSCode提供多种主题供用户选择,以适应不同的视觉偏好,如暗色主题、亮色主题等。
3.**扩展插件管理**-市场:VSCode的强大之处在于其丰富的扩展市场,可以从“扩展”面板中搜索并安装各种插件,如代码高亮、自动完成、Git集成等。
-安装插件:例如,为了更好地编写JavaScript,你可以安装"ES7React/Redux/React-Native/JSX"等插件,为Vue.js项目工作则可以安装"Vetur"。
4.**配置编辑器**-用户设置:VSCode允许用户自定义编辑器的行为,这可以通过`文件`->`首选项`->`设置`来访问。
在这里,你可以更改字体大小、颜色主题、代码缩进等设置。
-工作区设置:除了全局用户设置,还可以针对特定项目设置,这些设置仅对当前工作区生效。
5.**集成终端**-终端:VSCode内置了命令行终端,方便开发者在编辑器内运行命令,无需频繁切换窗口。
可以通过点击侧边栏的终端图标或使用快捷键`Ctrl+`(`Cmd+`onmacOS)来打开。
6.**Git集成**-版本控制:VSCode具有内置的Git支持,可以查看文件状态、提交更改、拉取和推送代码。
在源代码管理面板中,你可以看到未跟踪、已修改、已暂存的文件,并执行相应的Git操作。
7.**调试工具**-调试:VSCode的强大调试功能是其亮点之一,支持多种语言的调试配置。
通过创建`.vscode/launch.json`文件,可以设置断点、启动参数等,实现快速调试。
8.**代码片段**-代码片段:VSCode允许用户创建自定义代码片段,提高编码效率。
例如,你可以为常用的HTML标签、JavaScript函数等创建快捷输入。
9.**多语言支持**-语言支持:VSCode内置了对多种编程语言的支持,如JavaScript、TypeScript、Python、C++等,并提供语法高亮、智能提示等功能。
10.**视频教程与配置文件**-视频教程:提供的详细视频教程可以帮助初学者更好地理解和使用VSCode,涵盖从基本操作到高级特性的方方面面。
-配置文件:如果压缩包中包含配置文件,你可以导入这些配置,使你的VSCode环境与教程保持一致,便于学习。
VSCodeSetup-x64-1.19.1的安装和配置是学习高效开发的重要步骤,结合视频教程和配置文件,能让你快速掌握这款强大的代码编辑器。
随着对VSCode的深入理解和实践,你会发现它是一款不可或缺的开发工具。
2025/7/18 14:04:50 68.36MB  VScode
1
本程序采用msp430f149单片机进行频率及幅度采集,并在12864显示屏上显示,使用C语言编程,本人已在msp430f149单片机上进行过实验,并且可以正确的在12864显示屏上显示
2025/7/17 15:14:37 108KB msp430频率采集
1
本书提供了近90个常用的数值计算算法的原理和Java实现方法,所有的算法都集成在一个包中,可以不加修改地直接用于实际应用。
堪称java算法百科全书。
2025/7/17 8:55:41 5.4MB Java 算法 编程
1
全书共分10章。
第1章介绍PowerBuilder9.0的特性、PowerBuilder集成开发环境的组成与使用以及用PowerBuilder开发一个应用程序的基本过程。
第2章介绍PowerBuilder提供的AdaptiveServerAnywhere数据库管理系统的使用,包括数据库、表、主键、外键、索引、视图的创建以及数据操纵和安全管理。
第3章介绍PowerScript编程语言的语法规则、数据类型、控制语句和嵌入式SQL语句,并介绍面向对象程序设计技术。
第4章介绍应用的有关概念以及应用对象的创建方法和典型脚本的编写。
第5章介绍窗口对象的创建及属性设置方法、窗口中常用控件的属性设置及常用事件的编程。
第6章介绍菜单对象的创建、属性设置及典型编程。
第7章介绍数据窗口对象的创建方法、数据窗口中控件对象的属性设置和添加新对象的方法,并介绍数据窗口控件及实现典型数据操作的函数。
第8章介绍用户对象和用户事件的概念及创建与使用方法。
第9章介绍应用程序的调试方法、生成可执行程序的方法以及应用系统安装程序的制作方法。
第10章通过“学生成绩管理系统”实例,详细系统地介绍使用PowerBuilder开发数据库应用系统的方法和过程。
2025/7/17 5:49:48 7.31MB PB9.0学习资料
1
张友生_远程控制编程技术(高清).pdf
2025/7/17 5:32:38 48.76MB 远程控制
1
C++并发编程实战代码
2025/7/16 20:02:34 1KB c++
1
共 1000 条记录 首页 上一页 下一页 尾页
在日常工作中,钉钉打卡成了我生活中不可或缺的一部分。然而,有时候这个看似简单的任务却给我带来了不少烦恼。 每天早晚,我总是得牢记打开钉钉应用,点击"工作台",再找到"考勤打卡"进行签到。有时候因为工作忙碌,会忘记打卡,导致考勤异常,影响当月的工作评价。而且,由于我使用的是苹果手机,有时候系统更新后,钉钉的某些功能会出现异常,使得打卡变得更加麻烦。 另外,我的家人使用的是安卓手机,他们也经常抱怨钉钉打卡的繁琐。尤其是对于那些不太熟悉手机操作的长辈来说,每次打卡都是一次挑战。他们总是担心自己会操作失误,导致打卡失败。 为了解决这些烦恼,我开始思考是否可以通过编写一个全自动化脚本来实现钉钉打卡。经过一段时间的摸索和学习,我终于成功编写出了一个适用于苹果和安卓系统的钉钉打卡脚本。
2024-04-09 15:03 15KB 钉钉 钉钉打卡