基于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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

基于人工智能的图像分类系统

目录 引言项目背景环境准备 硬件要求软件安装与配置系统设计 系统架构关键技术代码示例 数据预处理模型训练模型预测应用场景结论 1. 引言 图像分类是计算机视觉中的一个重要任务,目标是自动识别图像中的对象类别。通过卷积神经网络(CNN)等深度学习技术,我们可以构建高效的图像分类系统,广泛应用于自动驾驶、医疗影像诊断、监控分析等领域。本文将介绍如何构建一个基于人工智能的图像分类系统,包括环境