基于SpringBoot的家庭理财记账系统的设计与开发

2024-01-07 03:20

本文主要是介绍基于SpringBoot的家庭理财记账系统的设计与开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.引言

随着社会的发展,社会的方方面面都在利用信息化时代的优势。互联网的优势和普及使得各种系统的开发成为必需。

本文以实际运用为开发背景,运用软件工程原理和开发方法,它主要是采用java语言技术和mysql数据库来完成对系统的设计。整个开发过程首先对家庭理财记账系统进行需求分析,得出家庭理财记账系统主要功能。接着对家庭理财记账系统进行总体设计和详细设计。总体设计主要包括系统功能设计、系统总体结构设计、系统数据结构设计和系统安全设计等;详细设计主要包括家庭理财记账系统数据库访问的实现,主要功能模块的具体实现,模块实现关键代码等。最后对家庭理财记账系统进行了功能测试,并对测试结果进行了分析总结,得出家庭理财记账系统存在的不足及需要改进的地方,为以后的家庭理财记账系统维护提供了方便,同时也为今后开发类似家庭理财记账系统提供了借鉴和帮助。

家庭理财记账系统开发使系统能够更加方便快捷,同时也促使家庭理财记账系统变的更加系统化、有序化。系统界面较友好,易于操作。

2.开发技术

2.1 B/S架构

B/S结构的特点也非常多,例如在很多浏览器中都可以做出信号请求。并且可以适当的减轻用户的工作量,通过对客户端安装或者是配置少量的运行软件就能够逐步减少用户的工作量,这些功能的操作主要是由服务器来进行控制的,由于该软件的技术不断成熟,最主要的特点就是与浏览器相互配合为软件开发带来了极大的便利,不仅能够减少开发成本,还能够不断加强系统的软件功能,层层相互独立和展现层是该B/S结构完成相互连接的主要特性。

2.2 系统框架以及目录结构介绍

整个系统框架系统分为两部分:逻辑层视图层。系统开发框架的目标是通过尽可能简单、高效的方式让开发者可以在微信中开发具有原生系统体验的服务。系统在视图层与逻辑层间提供了数据传输和事件系统,提供了自己的视图层以及逻辑层框架,让开发者能够专注于数据与逻辑。框架的核心是一个响应的数据绑定系统,可以让数据与视图非常简单地保持同步。在逻辑层做数据修改,在视图层就会做相应的更新。框架提供了一套基础的组件,这些组件自带微信风格的样式以及特殊的逻辑,开发者可以通过组合基础组件,创建出强大的系统 。

2.3 JAVA

Java主要采用CORBA技术和安全模型,可以在互联网应用的数据保护。它还提供了对EJB(Enterprise JavaBeans)的全面支持,java servlet API,JSP(java server pages),和XML技术。多进步。例如,当我在微软Word中写这篇文章时,我还打开了一个MP3播放器来播放音乐。偶尔,我也会编辑Word,让支出分类信息管理机器执行打印作业,我也喜欢通过IE。对我来说,这些操作是同时执行的,我不需要等待一首歌来完成支出分类信息管理论文编辑。似乎他们都在支出分类信息管理机器上同时为我工作。事实是,对于一个CPU,它只能在某个时间点执行一个程序。CPU在这些程序之间不断地“跳跃”。那么为什么我们看不到任何破坏呢?这是因为,与我们的感情相比,它的速度太快了。因此,尽管我们看到一些同步操作,实际上对于计算机来说,它只能在某个时间点执行一个程序,除非您的计算机是多CPU的。

Java是一种计算机编程语言,具有封装、继承和多态性三个主要特性,广泛应用于企业Web应用程序开发和移动应用程序开发。

Java语言和一般编译器以及直译的区别在于,Java首先将源代码转换为字节码,然后将其转换为JVM的可执行文件,JVM可以在各种不同的JVM上运行。因此,实现了它的跨平台特性。虽然这使得Java在早期非常缓慢,但是随着Java的开发,它已经得到了明显改进。

2.4 MySQL数据库

Mysql的语言是非结构化的,用户可以在数据上进行工作。MySQL因为其速度、可靠性和适应性而备受关注。大多数人都认为在不需要事务化处理的情况下,MySQL是管理内容最好的选择。并且因为Mysql的语言和结构比较简单,但是功能和存储信息量很强大,所以得到了普遍的应用。

Mysql数据库在编程过程中的作用是很广泛的,为用户进行数据查询带来了方便。Mysql数据库的应用因其灵活性强,功能强大,所以在实现某功能时只需要一小段代码,而不像其他程序需要编写大段代码。总体来说,Mysql数据库的语言相对要简洁很多。

数据流程分析主要就是数据存储的储藏室,它是在计算机上进行的,而不是现实中的储藏室。数据的存放是按固定格式,而不是无序的,其定义就是:长期有固定格式,可以共享的存储在计算机存储器上。数据库管理主要是数据存储、修改和增加以及数据表的建立。为了保证系统数据的正常运行,一些有能力的处理者可以进行管理而不需要专业的人来处理。数据表的建立,可以对数据表中的数据进行调整,数据的重新组合及重新构造,保证数据的安全性。介于数据库的功能强大等特点,本系统的开发主要应用了Mysql进行对数据的管理。

2.5 SpringBoot框架

Spring Boot是在原来Spring的基础上进行开发的,并且它可以快速创建一个应用框架。它的设计思想是简化Spring应用的搭建和开发过程,提供一种“开箱即用”的方式来创建单独的、生产级别的Spring应用程序[10]。

Spring Boot为了降低开发Spring应用程序的复杂性,提供了如下的一些特性。例如:

(1)配置自动化:该框架包含了很多默认的配置,让开发者在不需要进行手动配置的情况下还能够使用非常多的常见功能。

(2)快速开发:通过使用Spring Starter项目快速开始一个项目,并利用Spring Boot的自动配置特性快速搭建应用。

(3)内嵌式Web容器:Spring Boot内置了Tomcat、Jetty或Undertow,使得开发者无需手动部署和配置Web服务器。

(4)应用监控:Spring Boot提供了丰富的指标和监控工具,作为开发者诊断应用和理解程序的工具。

3.功能设计

系统分为用户端和管理端。管理端包含首页、个人中心、用户管理、家庭账户管理、收入分类管理、支出分类管理、家庭收入管理、家庭支出管理、银行储蓄账户、系统管理、投资理财管理。用户端包含银行储蓄管理、收入、个人中心、家庭账户管理、家庭收入管理、家庭支出管理、投资理财管理。

4.功能效果图

4.1 用户端功能模块

用户注册,用户注册页面可以填写个人账号、姓名、身份证号码、手机号码等信息进行注册如图所示

用户登录,在用户登录页面填写账号、密码进行登录如图所示。

 用户登录到家庭理财记账系统可以查看首页、家庭账户管理、收入分类管理、银行储蓄管理等内容,如图所示。 

用户信息页面可以填写个人账号、姓名、性别、年龄、身份证号码、手机号码、头像信息,并可根据需要进行保存、退出登录,如图所示。 

4.2 管理员端功能模块

管理员通过填写用户名、密码、角色进行登录如图所示。

用户管理,通过填写个人账号、姓名、性别、年龄、身份证号码、手机号码、头像等信息进行详情、修改、删除操作,如图所示。 

家庭账户管理,通过填写用户名,账户号,用户姓名,金额等信息进行修改、删除操作,如图所示。 

 收入分类管理,通过填写收入分类名等信息进行详情、修改、删除操作,如图所示。

支出分类信息管理,通过填写支出分类名等信息进行详情、修改、删除操作,如图所示。 

家庭收入管理,通过填写用户名,用户姓名,账户号,收入分类,金额,日期,备注等信息进行详情、修改、删除操作,如图所示。 

 家庭支出管理,通过填写用户名,用户姓名,账户号,支出分类,金额,日期,备注等信息进行详情、修改操作,如图所示。 

5.核心代码

@RestController
@RequestMapping("/jiatingshouru")
public class JiatingshouruController {@Autowiredprivate JiatingshouruService jiatingshouruService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,JiatingshouruEntity jiatingshouru,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {jiatingshouru.setYonghuming((String)request.getSession().getAttribute("username"));}EntityWrapper<JiatingshouruEntity> ew = new EntityWrapper<JiatingshouruEntity>();PageUtils page = jiatingshouruService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingshouru), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,JiatingshouruEntity jiatingshouru, HttpServletRequest request){EntityWrapper<JiatingshouruEntity> ew = new EntityWrapper<JiatingshouruEntity>();PageUtils page = jiatingshouruService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingshouru), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( JiatingshouruEntity jiatingshouru){EntityWrapper<JiatingshouruEntity> ew = new EntityWrapper<JiatingshouruEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingshouru, "jiatingshouru")); return R.ok().put("data", jiatingshouruService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(JiatingshouruEntity jiatingshouru){EntityWrapper< JiatingshouruEntity> ew = new EntityWrapper< JiatingshouruEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingshouru, "jiatingshouru")); JiatingshouruView jiatingshouruView =  jiatingshouruService.selectView(ew);return R.ok("查询家庭收入成功").put("data", jiatingshouruView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){JiatingshouruEntity jiatingshouru = jiatingshouruService.selectById(id);return R.ok().put("data", jiatingshouru);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){JiatingshouruEntity jiatingshouru = jiatingshouruService.selectById(id);return R.ok().put("data", jiatingshouru);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody JiatingshouruEntity jiatingshouru, HttpServletRequest request){jiatingshouru.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingshouru);jiatingshouruService.insert(jiatingshouru);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody JiatingshouruEntity jiatingshouru, HttpServletRequest request){jiatingshouru.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingshouru);jiatingshouruService.insert(jiatingshouru);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody JiatingshouruEntity jiatingshouru, HttpServletRequest request){//ValidatorUtils.validateEntity(jiatingshouru);jiatingshouruService.updateById(jiatingshouru);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){jiatingshouruService.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<JiatingshouruEntity> wrapper = new EntityWrapper<JiatingshouruEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));}int count = jiatingshouruService.selectCount(wrapper);return R.ok().put("count", count);}}
@RestController
@RequestMapping("/jiatingzhanghu")
public class JiatingzhanghuController {@Autowiredprivate JiatingzhanghuService jiatingzhanghuService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,JiatingzhanghuEntity jiatingzhanghu,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {jiatingzhanghu.setYonghuming((String)request.getSession().getAttribute("username"));}EntityWrapper<JiatingzhanghuEntity> ew = new EntityWrapper<JiatingzhanghuEntity>();PageUtils page = jiatingzhanghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingzhanghu), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,JiatingzhanghuEntity jiatingzhanghu, HttpServletRequest request){EntityWrapper<JiatingzhanghuEntity> ew = new EntityWrapper<JiatingzhanghuEntity>();PageUtils page = jiatingzhanghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingzhanghu), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( JiatingzhanghuEntity jiatingzhanghu){EntityWrapper<JiatingzhanghuEntity> ew = new EntityWrapper<JiatingzhanghuEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingzhanghu, "jiatingzhanghu")); return R.ok().put("data", jiatingzhanghuService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(JiatingzhanghuEntity jiatingzhanghu){EntityWrapper< JiatingzhanghuEntity> ew = new EntityWrapper< JiatingzhanghuEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingzhanghu, "jiatingzhanghu")); JiatingzhanghuView jiatingzhanghuView =  jiatingzhanghuService.selectView(ew);return R.ok("查询家庭账户成功").put("data", jiatingzhanghuView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){JiatingzhanghuEntity jiatingzhanghu = jiatingzhanghuService.selectById(id);return R.ok().put("data", jiatingzhanghu);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){JiatingzhanghuEntity jiatingzhanghu = jiatingzhanghuService.selectById(id);return R.ok().put("data", jiatingzhanghu);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody JiatingzhanghuEntity jiatingzhanghu, HttpServletRequest request){jiatingzhanghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingzhanghu);jiatingzhanghuService.insert(jiatingzhanghu);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody JiatingzhanghuEntity jiatingzhanghu, HttpServletRequest request){jiatingzhanghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingzhanghu);jiatingzhanghuService.insert(jiatingzhanghu);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody JiatingzhanghuEntity jiatingzhanghu, HttpServletRequest request){//ValidatorUtils.validateEntity(jiatingzhanghu);jiatingzhanghuService.updateById(jiatingzhanghu);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){jiatingzhanghuService.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<JiatingzhanghuEntity> wrapper = new EntityWrapper<JiatingzhanghuEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));}int count = jiatingzhanghuService.selectCount(wrapper);return R.ok().put("count", count);}}
@RestController
@RequestMapping("/jiatingzhichu")
public class JiatingzhichuController {@Autowiredprivate JiatingzhichuService jiatingzhichuService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,JiatingzhichuEntity jiatingzhichu,HttpServletRequest request){String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {jiatingzhichu.setYonghuming((String)request.getSession().getAttribute("username"));}EntityWrapper<JiatingzhichuEntity> ew = new EntityWrapper<JiatingzhichuEntity>();PageUtils page = jiatingzhichuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingzhichu), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,JiatingzhichuEntity jiatingzhichu, HttpServletRequest request){EntityWrapper<JiatingzhichuEntity> ew = new EntityWrapper<JiatingzhichuEntity>();PageUtils page = jiatingzhichuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiatingzhichu), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( JiatingzhichuEntity jiatingzhichu){EntityWrapper<JiatingzhichuEntity> ew = new EntityWrapper<JiatingzhichuEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingzhichu, "jiatingzhichu")); return R.ok().put("data", jiatingzhichuService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(JiatingzhichuEntity jiatingzhichu){EntityWrapper< JiatingzhichuEntity> ew = new EntityWrapper< JiatingzhichuEntity>();ew.allEq(MPUtil.allEQMapPre( jiatingzhichu, "jiatingzhichu")); JiatingzhichuView jiatingzhichuView =  jiatingzhichuService.selectView(ew);return R.ok("查询家庭支出成功").put("data", jiatingzhichuView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){JiatingzhichuEntity jiatingzhichu = jiatingzhichuService.selectById(id);return R.ok().put("data", jiatingzhichu);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){JiatingzhichuEntity jiatingzhichu = jiatingzhichuService.selectById(id);return R.ok().put("data", jiatingzhichu);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody JiatingzhichuEntity jiatingzhichu, HttpServletRequest request){jiatingzhichu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingzhichu);jiatingzhichuService.insert(jiatingzhichu);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody JiatingzhichuEntity jiatingzhichu, HttpServletRequest request){jiatingzhichu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(jiatingzhichu);jiatingzhichuService.insert(jiatingzhichu);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody JiatingzhichuEntity jiatingzhichu, HttpServletRequest request){//ValidatorUtils.validateEntity(jiatingzhichu);jiatingzhichuService.updateById(jiatingzhichu);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){jiatingzhichuService.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<JiatingzhichuEntity> wrapper = new EntityWrapper<JiatingzhichuEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}String tableName = request.getSession().getAttribute("tableName").toString();if(tableName.equals("yonghu")) {wrapper.eq("yonghuming", (String)request.getSession().getAttribute("username"));}int count = jiatingzhichuService.selectCount(wrapper);return R.ok().put("count", count);}}
@RestController
@RequestMapping("/shourufenlei")
public class ShourufenleiController {@Autowiredprivate ShourufenleiService shourufenleiService;/*** 后端列表*/@RequestMapping("/page")public R page(@RequestParam Map<String, Object> params,ShourufenleiEntity shourufenlei,HttpServletRequest request){EntityWrapper<ShourufenleiEntity> ew = new EntityWrapper<ShourufenleiEntity>();PageUtils page = shourufenleiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shourufenlei), params), params));return R.ok().put("data", page);}/*** 前端列表*/@RequestMapping("/list")public R list(@RequestParam Map<String, Object> params,ShourufenleiEntity shourufenlei, HttpServletRequest request){EntityWrapper<ShourufenleiEntity> ew = new EntityWrapper<ShourufenleiEntity>();PageUtils page = shourufenleiService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shourufenlei), params), params));return R.ok().put("data", page);}/*** 列表*/@RequestMapping("/lists")public R list( ShourufenleiEntity shourufenlei){EntityWrapper<ShourufenleiEntity> ew = new EntityWrapper<ShourufenleiEntity>();ew.allEq(MPUtil.allEQMapPre( shourufenlei, "shourufenlei")); return R.ok().put("data", shourufenleiService.selectListView(ew));}/*** 查询*/@RequestMapping("/query")public R query(ShourufenleiEntity shourufenlei){EntityWrapper< ShourufenleiEntity> ew = new EntityWrapper< ShourufenleiEntity>();ew.allEq(MPUtil.allEQMapPre( shourufenlei, "shourufenlei")); ShourufenleiView shourufenleiView =  shourufenleiService.selectView(ew);return R.ok("查询收入分类成功").put("data", shourufenleiView);}/*** 后端详情*/@RequestMapping("/info/{id}")public R info(@PathVariable("id") Long id){ShourufenleiEntity shourufenlei = shourufenleiService.selectById(id);return R.ok().put("data", shourufenlei);}/*** 前端详情*/@RequestMapping("/detail/{id}")public R detail(@PathVariable("id") Long id){ShourufenleiEntity shourufenlei = shourufenleiService.selectById(id);return R.ok().put("data", shourufenlei);}/*** 后端保存*/@RequestMapping("/save")public R save(@RequestBody ShourufenleiEntity shourufenlei, HttpServletRequest request){shourufenlei.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(shourufenlei);shourufenleiService.insert(shourufenlei);return R.ok();}/*** 前端保存*/@RequestMapping("/add")public R add(@RequestBody ShourufenleiEntity shourufenlei, HttpServletRequest request){shourufenlei.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//ValidatorUtils.validateEntity(shourufenlei);shourufenleiService.insert(shourufenlei);return R.ok();}/*** 修改*/@RequestMapping("/update")public R update(@RequestBody ShourufenleiEntity shourufenlei, HttpServletRequest request){//ValidatorUtils.validateEntity(shourufenlei);shourufenleiService.updateById(shourufenlei);//全部更新return R.ok();}/*** 删除*/@RequestMapping("/delete")public R delete(@RequestBody Long[] ids){shourufenleiService.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<ShourufenleiEntity> wrapper = new EntityWrapper<ShourufenleiEntity>();if(map.get("remindstart")!=null) {wrapper.ge(columnName, map.get("remindstart"));}if(map.get("remindend")!=null) {wrapper.le(columnName, map.get("remindend"));}int count = shourufenleiService.selectCount(wrapper);return R.ok().put("count", count);}}

6.参考论文

目  录

摘 要

Abstract 1

1 系统概述 2

1.1 概述 3

1.2课题意义 4

1.3 主要内容

2 系统开发环境

2.1B/S架构

2.2系统框架以及目录结构介绍

2.3 JAVA简介

2.4 MySQL数据库

2.5 SpringBoot框架

3 需求分析 8

3.1 系统设计目标 8

3.2需求分析概述 9

3.3 系统可行性分析 9

3.4经济可行性 10

3.5操作可行性:  11

3.6系统流程和逻辑 12

4系统概要设计 13

4.1 概述 14

4.2 系统结构 15

4.3. 数据库设计 16

4.3.1 数据库设计表 18

5系统详细设计 18

5.1用户端功能模块 19

5.2管理端功能模块 20

6 系统测试

6.1 测试理论

6.2 测试方法及用例

6.3测试结果

结论

致 谢

参考文献

7.总结

家庭理财记账系统的设计,通过互联网来解决实现信息化的网站系统,通过我四年所学的所有专业知识整合一起,进行对家庭理财记账系统进行开发设计,当然在真正着手来做的时候遇到了很多问题,一个是网站的技术问题,一个是自己之前没有单独开发过程序,动手实践比较少,面对问题的同时,自己的自信心也受到了一些打击,不过我也是快速的调整自己的状态,老师与同学讨论的方法解决了所有的困难。

毕业设计是我们所学知识应用的最佳体现,也是在考核我们四年中所学的所有的专业知识及技术应用情况,通过这样毕业设计可以更好的得到锻炼及对所学知识的复习及运用,也是一种训练和实践。家庭理财记账系统的实现,不仅巩固了我以前的知识,还对学到的知识通过结合技术进行详细了解,还结合了对跨学科效果的深入理解。

在以后我的工作中,我仍然继续努力我的计算机方面的技术,让我在后期的平台开发中可以更好更快的实现需求功能。我相信自己可以胜任更多的好工作并在工作领域做出更大的贡献。

回顾毕业设计的整个过程,既付出了努力与汗水也收获了很多难以忘怀的美好经历。虽然在系统开发过程中经历了各种各样的困难,自己也在不断研究探索,可是系统的实现仍有许多不足之处。但是经过系统编程工作让我有了更多的信心,我相信在未来的路上,我会走的更好。

喜欢的点赞收藏加关注私信作者沟通交流

这篇关于基于SpringBoot的家庭理财记账系统的设计与开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/578563

相关文章

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

Java中List转Map的几种具体实现方式和特点

《Java中List转Map的几种具体实现方式和特点》:本文主要介绍几种常用的List转Map的方式,包括使用for循环遍历、Java8StreamAPI、ApacheCommonsCollect... 目录前言1、使用for循环遍历:2、Java8 Stream API:3、Apache Commons

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Java循环创建对象内存溢出的解决方法

《Java循环创建对象内存溢出的解决方法》在Java中,如果在循环中不当地创建大量对象而不及时释放内存,很容易导致内存溢出(OutOfMemoryError),所以本文给大家介绍了Java循环创建对象... 目录问题1. 解决方案2. 示例代码2.1 原始版本(可能导致内存溢出)2.2 修改后的版本问题在

Java CompletableFuture如何实现超时功能

《JavaCompletableFuture如何实现超时功能》:本文主要介绍实现超时功能的基本思路以及CompletableFuture(之后简称CF)是如何通过代码实现超时功能的,需要的... 目录基本思路CompletableFuture 的实现1. 基本实现流程2. 静态条件分析3. 内存泄露 bug

Java中Object类的常用方法小结

《Java中Object类的常用方法小结》JavaObject类是所有类的父类,位于java.lang包中,本文为大家整理了一些Object类的常用方法,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. public boolean equals(Object obj)2. public int ha

SpringBoot项目中Maven剔除无用Jar引用的最佳实践

《SpringBoot项目中Maven剔除无用Jar引用的最佳实践》在SpringBoot项目开发中,Maven是最常用的构建工具之一,通过Maven,我们可以轻松地管理项目所需的依赖,而,... 目录1、引言2、Maven 依赖管理的基础概念2.1 什么是 Maven 依赖2.2 Maven 的依赖传递机

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.