基于SpringBoot的“网上书城管理系统”的设计与实现(源码+数据库+文档+PPT)
-
开发语言:Java
-
数据库:MySQL
-
技术:SpringBoot
-
工具:IDEA/Ecilpse、Navicat、Maven
系统展示
系统功能结构图
系统首页界面图
用户注册界面图
图书信息界面图
个人中心界面图
购物车界面图
管理员登录界面图
管理员功能界面图
用户管理界面图
图书类型管理界面图
图书分类管理界面图
图书信息管理界面图
系统管理界面图
订单管理界面图
摘 要
在Internet高速发展的今天,我们生活的各个领域都涉及到计算机的应用,其中包括网上书城管理系统的网络应用,在国外网上书城管理系统已经是很普遍的方式,不过国内的书城管理系统可能还处于起步阶段。网上书城管理系统具有网上书城信息管理功能的选择。网上书城管理系统采用java技术,基于springboot框架,mysql数据库进行开发,实现了首页、个人中心、用户管理、图书类型管理、图书分类管理、图书信息管理、我的收藏管理、系统管理、订单管理等内容进行管理,本系统具有良好的兼容性和适应性,为用户提供更多的网上书城信息,也提供了良好的平台,从而提高系统的核心竞争力。
本文首先介绍了设计的背景与研究目的,其次介绍系统相关技术,重点叙述了系统功能分析以及详细设计,最后总结了系统的开发心得。
课题背景
。
使用网上书城系统相对传统书城管理方式具备很多优点:首先可以大幅提高网上书城信息检索,只需输入网上书城相关信息就能在数秒内反馈想要的结果;其次可存储大量的书城信息,同时网上书城信息安全性有更高的保障;相比纸质文件来管理方式具信息,网上书城管理系统更节省空间人力资源。这些优点大大提高效率并节省成本。因此,开发网上书城系统对网上书城信息进行有效的管理是很必要的,不仅提高了网上书城管理效率,增加了用户信息安全性,方便网上书城及时反馈信息给管理员,增加了用户与管理员之间的互动交流,更能提高网上书城的体验强度。
本系统为了数据库结构的灵活性所以打算采用MySQL来设计数据库,而java技术,B/S架构则保证了较高的平台适应性。本文主要介绍了本系统的开发背景,所要完成的功能和开发的过程,主要说明了系统设计的重点、设计思想。
系统实现的功能
本次设计任务是要设计一个网上书城管理系统,通过这个系统能够满足网上书城的管理及用户的图书信息管理及购物功能。系统的主要功能包括:首页、个人中心、用户管理、图书类型管理、图书分类管理、图书信息管理、我的收藏管理、系统管理、订单管理等功能。
管理员可以根据系统给定的账号进行登录,登录后可以进入网上书城管理系统,对网上书城管理系统所有模块进行管理。包括查看和修改自己的个人信息以及登录密码。
该系统为每一个用户都分配了一个用户账号,用户通过账号的登录可以在系统中查看网上书城信息及对个人信息进行修改等功能。
研究现状
网上书城管理系统能做到的不仅是大大简化管理员的信息管理工作,在提高网上书城管理系统运营的同时还能缩减开支,更能在数字化的平面网络上将网上书城管理系统最好的一面展示给客户和潜在客户,而这个系统在带给网上书城管理系统全新用户信息管理统计和分类的同时,还成为日后网上书城管理系统制定营销路线的重要数据参考。过程永远比结果重要。毕业设计是大学生活中最为浓墨重彩的一笔,在这个过程中不仅学到更为全面的书本和实践知识,更让我感受到了浓浓的同窗之情及师生情。这个系统成为网上书城管理者最不可或缺的内容。尽管目前大部分书城已经将网上书城管理系统投入使用,但是人们对于系统要求也变得越来越高,大部分系统已经能完美处理各类信息,但是为了更好地契合网上书城管理系统营销路线,不同网上书城管理系统有不同的要求,个性化也是管理系统十分重要的一点,所以每家书城都希望自己能有一个个性化定制的网上书城管理系统,但这又涉及到成本控制问题,目前定制一个系统价值不菲,但是如果有这样一个可以根据需求自己制定页面和内容的网上书城管理系统就可以大大缩减开支,但是凭借目前自身技术恐怕难以实现,不过让系统可二次设计却是有可能实现的。随着网上书城管理系统规模的不断扩大,用户信息共享也成一种趋势。网上书城管理系统的发展也证明了系统管理在不断发展进步,各种理念也越来越先进,对各方面的要求也变得越来越高,网上书城管理系统完全可以在进入页面时发布各类信息进行推荐交流。
部分源码
/*** 图书信息评论表* 后端接口* @author * @email * @date */
@RestController
@RequestMapping("/discusstushuxinxi")
public class DiscusstushuxinxiController {@Autowiredprivate DiscusstushuxinxiService discusstushuxinxiService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,DiscusstushuxinxiEntity discusstushuxinxi,HttpServletRequest request){EntityWrapper<DiscusstushuxinxiEntity> ew = new EntityWrapper<DiscusstushuxinxiEntity>();PageUtils page = discusstushuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, discusstushuxinxi), params), params));return R.ok().put("data", page);}/*** 前端列表*/@IgnoreAuth@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,DiscusstushuxinxiEntity discusstushuxinxi, HttpServletRequest request){EntityWrapper<DiscusstushuxinxiEntity> ew = new EntityWrapper<DiscusstushuxinxiEntity>();PageUtils page = discusstushuxinxiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, discusstushuxinxi), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( DiscusstushuxinxiEntity discusstushuxinxi){EntityWrapper<DiscusstushuxinxiEntity> ew = new EntityWrapper<DiscusstushuxinxiEntity>();ew.allEq(MPUtil.allEQMapPre( discusstushuxinxi, "discusstushuxinxi")); return R.ok().put("data", discusstushuxinxiService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(DiscusstushuxinxiEntity discusstushuxinxi){EntityWrapper< DiscusstushuxinxiEntity> ew = new EntityWrapper< DiscusstushuxinxiEntity>();ew.allEq(MPUtil.allEQMapPre( discusstushuxinxi, "discusstushuxinxi")); DiscusstushuxinxiView discusstushuxinxiView = discusstushuxinxiService.selectView(ew);return R.ok("查询图书信息评论表成功").put("data", discusstushuxinxiView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){DiscusstushuxinxiEntity discusstushuxinxi = discusstushuxinxiService.selectById(id);return R.ok().put("data", discusstushuxinxi);}/*** 前端详情*/@IgnoreAuth@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){DiscusstushuxinxiEntity discusstushuxinxi = discusstushuxinxiService.selectById(id);return R.ok().put("data", discusstushuxinxi);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody DiscusstushuxinxiEntity discusstushuxinxi, HttpServletRequest request){discusstushuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(discusstushuxinxi);discusstushuxinxiService.insert(discusstushuxinxi);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody DiscusstushuxinxiEntity discusstushuxinxi, HttpServletRequest request){discusstushuxinxi.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(discusstushuxinxi);discusstushuxinxiService.insert(discusstushuxinxi);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody DiscusstushuxinxiEntity discusstushuxinxi, HttpServletRequest request){//ValidatorUtils.validateEntity(discusstushuxinxi);discusstushuxinxiService.updateById(discusstushuxinxi);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){discusstushuxinxiService.deleteBatchIds(Arrays.asList(ids));return R.ok();}/*** 提醒接口*/@RequestMapping("/remind/{columnName}/{type}")public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, @PathVariable("type") String type,@RequestParam Map<String, Object> map) {map.put("column", columnName);map.put("type", type);if(type.equals("2")) {SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");Calendar c = Calendar.getInstance();Date remindStartDate = null;Date remindEndDate = null;if(map.get("remindstart")!=null) {Integer remindStart = Integer.parseInt(map.get("remindstart").toString());c.setTime(new Date()); c.add(Calendar.DAY_OF_MONTH,remindStart);remindStartDate = c.getTime();map.put("remindstart", sdf.format(remindStartDate));}if(map.get("remindend")!=null) {Integer remindEnd = Integer.parseInt(map.get("remindend").toString());c.setTime(new Date());c.add(Calendar.DAY_OF_MONTH,remindEnd);remindEndDate = c.getTime();map.put("remindend", sdf.format(remindEndDate));}}Wrapper<DiscusstushuxinxiEntity> wrapper = new EntityWrapper<DiscusstushuxinxiEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = discusstushuxinxiService.selectCount(wrapper);return R.ok().put("count", count);}}
结论
本网站使用了java开发技术与mysql数据库共同完成设计。在网站最后测试运行的时候,调试程序时,总是出现多处报错,通过查看错误提示,发现是数据库连接有问题,总是不正确。后来经过不断的查找才发现登录数据库的密码错误,随后修改数据库密码,这才正常调试了出来。解决问题还是在于查阅了有关java和mysql方面的图书、上了各种网上书城管理系统吸取成熟的经验。由于自己在之前的课程设计等学科上并没有很好的掌握知识,没有进一步的去自学网站的设计,对于一些框架技术基本都已不记得,更不会灵活的使用。所以这次的毕业设计,为了较好的完成,自己重新去图书馆借书研究,弥补之前丢失的知识。