摘 要
随着经济的发展和人们生活水平的提高,家庭理财管理变得愈发重要。然而,许多家庭对于如何有效地管理个人财务以及制定预算计划感到困惑。因此,本研究旨在提供一种简单、易用且功能全面的家庭理财管理工具。
本论文旨在设计和开发一款基于Android平台的家庭理财管理APP。家庭理财管理APP具备简洁直观的用户界面,使用户能够轻松地输入和跟踪个人财务信息。其次,引入了个性化定制功能,使用户能够根据自己的需求和目标制定预算计划,并能够根据实际情况进行调整。同时,该应用还提供智能数据分析功能,帮助用户深入了解个人财务状况,并提供相关建议和推荐。
综上所述,本论文设计和开发了一款基于Android平台的家庭理财管理APP,该应用具备简洁直观的用户界面、个性化定制和智能数据分析功能,能够帮助用户高效地管理个人财务并实现预算计划。此外,本论文还对该应用进行了验证实验和用户调研,结果显示其具备良好的功能和用户体验。
关键词:家庭理财管理APP;SSM框架;MySQL数据库;Android系统
Android based family financial management and implementation
Abstract
With the development of the economy and the improvement of people's living standards, family financial management has become increasingly important. However, many families are confused about how to effectively manage their personal finances and develop budget plans. Therefore, this study aims to provide a simple, user-friendly, and comprehensive family financial management tool.
This paper aims to design and develop a family financial management app based on the Android platform. The family financial management app has a simple and intuitive user interface, allowing users to easily input and track personal financial information. Secondly, the introduction of personalized customization function allows users to develop budget plans based on their own needs and goals, and adjust them according to actual situations. At the same time, the application also provides intelligent data analysis functions to help users gain a deeper understanding of their personal financial situation and provide relevant advice and recommendations.
In summary, this paper designs and develops a family financial management app based on the Android platform. The app has a simple and intuitive user interface, personalized customization, and intelligent data analysis functions, which can help users efficiently manage their personal finances and achieve budget planning. In addition, this paper also conducted validation experiments and user surveys on the application, and the results showed that it has good functionality and user experience.
Key words:Family financial management APP; SSM framework; MySQL database; Android system
目 录
第一章 绪论
1.1研究背景与意义
随着社会经济的发展和科技的进步,家庭理财管理变得越来越重要。随之而来的是需求日益增长的家庭理财管理工具。传统的家庭理财管理方式存在一些问题,如手动记录、难以实时监控、信息不集中等,导致家庭理财效率低下和管理不便利。因此,开发一款基于Android平台的家庭理财管理APP将有助于解决这些问题,提高家庭财务管理的效率和便利性。
当前,Android作为全球最受欢迎的移动操作系统之一,拥有庞大的用户群体,具有良好的用户体验和开发环境。通过结合Android平台的优势和家庭理财管理的需求,开发一款功能丰富、操作简单的家庭理财管理APP,能够为用户提供便捷、实用的理财工具,帮助他们更好地管理个人和家庭财务。
此外,家庭理财管理APP还能促进家庭成员之间的财务沟通与合作,帮助他们建立更加科学的消费观念和理财习惯,提高家庭财务管理的透明度和协同性。同时,家庭理财管理APP还可以为用户提供智能化的财务分析和推荐服务,帮助用户更好地规划财务目标和优化理财策略。
因此,基于Android的家庭理财管理APP的研发具有重要的研究意义和实际应用价值,有助于提升家庭理财管理的效率和质量,促进人们更科学地进行个人和家庭理财,实现财务规划和财务自由的管理。
1.2 研究现状
随着移动互联网的快速发展和智能手机的普及,家庭理财管理APP越来越受到人们关注。目前,市场上已经存在着各种各样的家庭理财管理APP,它们提供了多样化的功能和服务,帮助用户更好地管理个人财务。
(1)个人理财APP市场概况:在移动互联网时代,个人理财APP的市场规模不断扩大。大量的理财APP涌现,涵盖了个人理财、预算管理、账单管理、投资理财等方面。这些APP提供了便捷的功能和服务,帮助用户实现收支记录、预算制定、账单提醒等操作。
(2)主流家庭理财APP功能分析:现有的家庭理财APP功能丰富多样,主要包括账单管理、预算制定、理财分析、资产管理、账户同步等功能。用户可以通过这些功能实现财务情况的清晰展示和方便管理,助力用户做出更明智的理财决策。
(3)用户需求调查:随着社会生活水平的日益提高,人们对个人理财管理的重视程度也在增加。用户更加关注自己的财务状况,倾向于寻找能够帮助他们理财的工具。因此,对于家庭理财APP的需求呈现逐渐增长的趋势。
综上所述,当前家庭理财管理APP市场状况良好,用户对于此类APP的需求持续增加。因此,基于Android平台开发一款方便实用的家庭理财管理APP,将有望受到广大用户的青睐,为用户提供更好的理财。
1.3 研究任务
开发和实施基于Android的家庭理财管理和实现,需要完成以下任务:
(1)首先是确定选题,确定好所要做的系统,并对系统的背景及现在面临的一些问题等进行系统的初步确认。
(2)在系统ACK完成之后,我们将根据系统开发的要求,选择SSM技术来构建基于Android的家庭理财管理和实现,并对其中的数据库进行搭建和开发,以确保该系统能够有效地实现其功能。此外,我们还将对所选择的技术进行详细的技术分析,以确保系统的可行性和安全性。
(3)在家庭理财管理APP设计中,首先要确定系统的技术,然后进行在线确认,以确定系统的用户角色,并根据这些角色划分出相应的功能模块。系统的设计主要将用户分为管理员和普通用户两个主要角色,每个角色都有其独特的特点,而且每个功能模块都有其特定的功能,但是系统的数据库都是交互式的。
(4)经过精心设计的系统功能模块已经ACK完毕,接下来就是程序和界面的开发。为了检验程序的完整性,我们会采取多种测试方法,让不同的用户编写和提交相关内容,并定期检查程序中的缺陷,一旦发现问题,立即采取在线解决措施,直至系统运行稳定,才可以将其上传至正式使用。
1.4 论文结构安排
本文共分为七章,章节内容安排如下:
第一章:引言。此章节对所设计和实现的系统的背景和状况以及意义进行详细的论述以及说明,同时进行了论文整体框架的结构的简要介绍。
第二章:相关技术介绍。主要对本系统使用的相关技术和开发环境进行介绍。
第三章:系统需求分析。章节所做的主要的工作是对系统进行了技术、经济和操作方面可行性的分析;对系统实行了总体功能的需求、用例分析。
第四章:系统概要设计。主要是对系统的功能结构进行设计,并对系统数据库的概念结构以及物理结构的设计进行了分析。
第五章:系统实现。根据系统功能的划分,分别的对系统所需要实现的前台客户功能和后台管理员功能进行了分析和说明。
第六章:系统测试。主要对系统的部分界面进行测试并对主要功能进行测试
第七章:总结。
第二章 相关技术介绍
2.1 Android技术
Android是基于Linux内核的操作系统[1],早期由Google开发,后由开放手机联盟开发。它采用了软件堆的架构,主要分为三部分。底层以Linux内核工作为基础,只提供基本功能;其他的应用软件则由各公司自行开发,以Java作为编写程序的一部分。另外,为了推广此技术,Google和其它几十个手机公司建立了开放手机联盟。Android在未公开之前常被传闻为GPhone。
它采用了软件堆层(software stack,又名软件叠层)的架构,主要分为三部分:底层以Linux核心为基础,由C语言开发,只提供基本功能。中间层包括函数库Library和虚拟机Virtual Machine,由C++开发。最上层是各种应用软件,包括通话程序,短信程序等,应用软件则由各公司自行开发,以Java编写[2]。
2.2 Java语言
Java是一种面向对象的程序设计语言,类是Java程序的基本组成单元,类中又包含了属性和方法,在类中又可以创建无数个对象。类中包含的主要成员是字段和方法,字段是指一种数据变量,方法是指对字段进行操作的集合,包括给其他变量赋值、调用方法等[3]。
JDK为美国sun公司为java开发员所推出的一款全新产品,要是没有JDK的情况下,所安装的java程序也就无法运行[4]。
2.3 SSM框架
SSM(Spring+SpringMVC+MyBatis)框架集由Spring、MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容)。常作为数据源较简单的web项目的框架[5]。
1.8.1 Spring
Spring就像是整个项目中装配bean的大工厂,在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象。也可以称之为项目中的粘合剂。
Spring的核心思想是IoC(控制反转),即不再需要程序员去显式地`new`一个对象,而是让Spring框架帮你来完成这一切。
1.8.2 SpringMVC
SpringMVC在项目中拦截用户请求,它的核心Servlet即DispatcherServlet承担中介或是前台这样的职责,将用户请求通过HandlerMapping去匹配Controller,Controller就是具体对应请求所执行的操作[6]。SpringMVC相当于SSH框架中struts。
1.8.3 mybatis
mybatis是对jdbc的封装,它让数据库底层操作变的透明。mybatis的操作都是围绕一个sqlSessionFactory实例展开的。mybatis通过配置文件关联到各实体类的Mapper文件,Mapper文件中配置了每个类对数据库所需进行的sql语句映射。在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。
页面发送请求给控制器,控制器调用业务层处理逻辑,逻辑层向持久层发送请求,持久层与数据库交互,后将结果返回给业务层,业务层将处理逻辑发送给控制器,控制器再调用视图展现数据[7]。
2.4 MySQL数据库
MySQL数据库已经成为网络上的一种强大的工具,它能够支持多个用户,并且能够根据客户端和服务端的需求进行调整,从而满足不同的需求。在这里,服务端和客户端只是一种软件上的概念,而我们所使用的计算机硬件则没有必要完全相互匹配[8]。
MySQL作为一个受到广泛认可的开放式DBMS,其卓越的性能和易于操作的特性,以及其在多种操作环境中的灵活性,让其成为了众多AP中的首选。此外,MySQL还具有良好的跨平台性,让软件开发人员对其有着极高的评价。与传统的关联式数据库系统形式大相径庭,MySQL拥有一套完善的数据库管理策略,以确保用户的安全、稳健、安全。MySQL具备良好的容错、安全、快速、稳健的特点,使得mysql成为一款极其实用的数据库管理工具[9]。
MySQL拥有一种独特的权限分配机制,可以根据用户的身份和业务逻辑,为用户提供更多的选择,从而大大提高了MySQL的安全性和完整性,远超过其他关系型数据库。
MySQL具有强大的功能,能够处理各种数据类型,包括动态、静态、多种语言,从而使用户能够轻松访问多种数据。MySQL具有多种功能,它能够支持多种平台的开发,并且支持多种编程语言[10],使得用户能够轻松访问和使用MySQL数据库。
第三章 系统分析
3.1 可行性分析
3.1.1 技术可行性分析
基于Android的家庭理财管理和实现在数据的存储上使用的MySQL数据库,在家庭理财管理APP的设计与实现开发中使用了Java、HTML、Tomcat、SSM这些开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用B/S模式进行开发,使系统的可扩展性和维护性更佳,减少系统配置代码,简化编程代码,目前B/S模式是目前最受欢迎的一种模式。
3.1.2 经济可行性分析
从经济可行性上看项目在开发阶段需要一台开发PC和一台安卓移动设备,在生产阶段需要web服务器和数据库服务器。从经济上来看也不是太多问题,在后期的系统部署生产上来说,服务器的投入也不会过高,在经济层面上是一个比较可行的。
3.1.3 操作可行性分析
家庭理财管理APP的在开发的时候充分了解用户群体,对于使用智能机不熟练的用户也进行考虑在内,在APP的开发中首页有醒目的导航栏,使得即使没有使用过应用程序的用户,也可以根据导航栏的提示进行操作,非常方便,因此系统在操作上是可行的。
3.2 功能需求分析
家庭理财管理APP的功能主要分为普通用户和管理员两个角色。
普通用户功能模块:
(1)登录:家庭理财管理APP前台注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码后,点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到家庭理财管理APP的首页中;否则将会提示相应错误信息。
(2)首页:当用户进入家庭理财管理APP的时候,首先映入眼帘的是系统的导航栏包括:首页(理财项目)、我的(基本信息、收藏、统计图、家庭支出、家庭收入、理财购买、盈亏情况、理财卖出)等内容。
(3)理财项目:用户可以查看理财项目,支持通过搜索关键词的方式对理财项目进行查询,在查询到自己想要了解的理财项目的时候,可以进入查看详细的介绍,可以查看到项目风险、项目类型、项目名称、项目图片、项目收益、收益排名、项目详情等信息,并且可以对查看的理财项目进行购买、点赞、收藏和评论操作。
(4)我的模块:普通用户在前台点击“我的”可以对用户的基本信息、收藏、统计图、家庭支出、家庭收入、理财购买、盈亏情况、理财卖出等信息进行管理。
普通用户用例图如下图所示。
图3-1 普通用户功能模块图
管理员功能模块:
(1)系统用户:包括用户账号的添加、编辑和删除操作,可以查看用户信息、修改用户权限、冻结或解冻用户账号等。
(2)收入类型管理:点击“收入类型管理”系统会把家庭理财管理APP当中所有的收入类型信息都显示出来,管理员可进行添加收入类型和类型描述管理,并可进行查询、重置或删除等相应操作。
(3)支出类型管理:点击“支出类型管理”系统会把家庭理财管理APP当中所有的支出类型信息都显示出来,管理员可进行添加支出类型和类型描述管理,并可进行查询、重置或删除等相应操作。
(4)家庭支出管理:管理员点击“家庭支出管理”可以对前台用户的家庭支出信息进行管理。
(5)家庭收入管理:管理员点击“家庭收入管理”可以对前台用户的家庭收入信息进行管理。
(6)理财项目管理:当管理员点击“理财项目管理”时,可查看理财项目列表和理财项目添加。点击“理财项目添加”,选择项目风险、项目类型、项目名称、项目图片、项目收益、收益排名、项目详情等信息,点击“提交”按钮,可添加新的理财项目。也可以对用户的评论信息进行管控。
(7)理财购买管理:管理员点击“理财购买管理”菜单可以查看前台用户提交的所有的理财购买订单信息列表,可以进行审核并处理订单信息。
(8)盈亏情况管理:管理员点击“盈亏情况管理”可以对理财项目的盈亏情况信息进行管理。
(9)理财卖出管理:管理员点击“理财卖出管理”可以对理财项目的理财卖出信息进行管理。
(10)系统管理:当管理员点击“系统管理”时,可查看轮播图管理,如需添加新的轮播图,点击右侧“新增”按钮,上传图片,输入标题,点击“确认”按钮进行添加。
管理员用例图如下所示。
图3-2 管理员用例图
3.3 非功能需求分析
基于上面功能性需求,非功能需求也是项目设计中一项必定考虑进去的工作。首先是安全性的需求,其次是界面必须整洁干净等的需求,再次就是可扩展的需求。除此之外,还有性能、可靠性的需求,具体可以表示在如下表所示。
表3-1 系统非功能需求表
安全性 | 只有在登录的情况下才能进行相应功能的操作,尤其是管理员功能,防止后台管理端被侵入。 |
可靠性 | 系统的功能明确,操作一个功能,不会产生额外的功能影响,操作功能的时候,页面也不会造成额外的跳动。 |
性能 | 响应时间尽量控制在1s之内 |
可扩展性 | 后台采用自顶向下的开发,利于开发与维护。 |
易用性 | 在用户使用上,尽可能使用更多的图标进行功能暗示,提供系统的可阅读性和友好性。 |
可维护性 | 前台和后台注意按照模块化开发的原则,对于组件和方法的保存和包的建立需要遵照一般开发原则,以利于维护。 |
3.4 安全性需求分析
3.4.1 系统的安全性
安全性对每一个系统来说都是非常重要的。安全性很好的系统可以保护企业的信息和用户的信息不被窃取。提高系统的安全性不仅是对用户的负责,更是对企业的负责。尤其针对于家庭理财管理APP来说,必须要有很好的安全性来保障整个系统。
系统具有对使用者有权限控制,针对角色的不通限制使用者的权限,以此来确保系统的安全性。
3.4.2 数据的安全性
数据库中的数据是从外界输入的,当数据的输入时,由于种种原因,输入的数据会无效,或者是脏数据。因此,怎样保证输入的数据符合规定,成为了数据库系统,尤其是多用户的关系数据库系统首要关注的问题。
因此,在写入数据库时,要保证数据完整性、正确性和一致性。
3.5 数据开发流程分析
家庭理财管理APP开发对管理模块和系统使用的数据库进行分析,编写代开发,规划和操作是构建信息管理应用程序的必要三步曲,它决定了系统是否能够真正实现预设功能以及是否可以在成功设计后实施。在开发过程中,每个阶段必须严格按照线性顺序进行开发,并且在相应阶段生成的每个工作都可以通过技术进行验证和检查。确保一个阶段完成后是正确的,不会造成下一阶段拖拽现象,使系统完成设计功能后得到保证。
从家庭理财管理APP成功开发经验来看,上述方法效果最为明显,最大程度地降低了系统开发的复杂性。如图3-4所示。
图3-4 系统开发流程图
3.6 系统流程分析
3.6.1 数据流程
开发家庭理财管理APP最主要的一个目的就是实现用户对理财项目的购买,系统的数据流图如下所示。
图3-5理财项目购买展开图
3.6.2 业务流程
分析完家庭理财管理APP的数据流程,那么接下来我们来看系统的业务流程,系统业务流程图如下:
图3-5系统业务流程图
第四章 系统设计
4.1 系统功能结构
家庭理财管理APP总体分为普通用户模块和后台管理员模块。两个模块表现上是分别独立存在,但是访问的数据库是一样的。每一个模块的功能都是根据先前完成的需求分析,并查阅相关资料后整理制作的。
综上所述,系统功能结构图如下图所示。
图4-1 系统功能结构图
4.2 数据库设计
4.2.1 数据库概念设计
E-R图一般是由实体、实体的属性与联系三个要素组成的。在规划系统中所使用的数据库实体对象及实体E-R图,则需要通过对系统的需求分析、业务流程设计和系统功能结构来确定的。
总体E-R图如下图所示。
图4-2 系统ER图
4.2.2 数据库表设计
数据库是家庭理财管理APP的数据处理的基础,也是为界面数据的展示与存储的关键。家庭理财管理APP的数据库表如下。
表access_token (登陆访问时长)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | token_id | int | 10 | 0 | N | Y | 临时访问牌ID | |
2 | token | varchar | 64 | 0 | Y | N | 临时访问牌 | |
3 | info | text | 65535 | 0 | Y | N | ||
4 | maxage | int | 10 | 0 | N | N | 2 | 最大寿命:默认2小时 |
5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
7 | user_id | int | 10 | 0 | N | N | 0 | 用户编号: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | auth_id | int | 10 | 0 | N | Y | 授权ID: | |
2 | user_group | varchar | 64 | 0 | Y | N | 用户组: | |
3 | mod_name | varchar | 64 | 0 | Y | N | 模块名: | |
4 | table_name | varchar | 64 | 0 | Y | N | 表名: | |
5 | page_title | varchar | 255 | 0 | Y | N | 页面标题: | |
6 | path | varchar | 255 | 0 | Y | N | 路由路径: | |
7 | position | varchar | 32 | 0 | Y | N | 位置: | |
8 | mode | varchar | 32 | 0 | N | N | _blank | 跳转方式: |
9 | add | tinyint | 3 | 0 | N | N | 1 | 是否可增加: |
10 | del | tinyint | 3 | 0 | N | N | 1 | 是否可删除: |
11 | set | tinyint | 3 | 0 | N | N | 1 | 是否可修改: |
12 | get | tinyint | 3 | 0 | N | N | 1 | 是否可查看: |
13 | field_add | text | 65535 | 0 | Y | N | 添加字段: | |
14 | field_set | text | 65535 | 0 | Y | N | 修改字段: | |
15 | field_get | text | 65535 | 0 | Y | N | 查询字段: | |
16 | table_nav_name | varchar | 500 | 0 | Y | N | 跨表导航名称: | |
17 | table_nav | varchar | 500 | 0 | Y | N | 跨表导航: | |
18 | option | text | 65535 | 0 | Y | N | 配置: | |
19 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | collect_id | int | 10 | 0 | N | Y | 收藏ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 收藏人ID: |
3 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
4 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
5 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
6 | title | varchar | 255 | 0 | Y | N | 标题: | |
7 | img | varchar | 255 | 0 | Y | N | 封面: | |
8 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | comment_id | int | 10 | 0 | N | Y | 评论ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 评论人ID: |
3 | reply_to_id | int | 10 | 0 | N | N | 0 | 回复评论ID:空为0 |
4 | content | longtext | 2147483647 | 0 | Y | N | 内容: | |
5 | nickname | varchar | 255 | 0 | Y | N | 昵称: | |
6 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
9 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
10 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
11 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | expenditure_type_id | int | 10 | 0 | N | Y | 支出类型ID | |
2 | expenditure_type | varchar | 64 | 0 | Y | N | 支出类型 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | financial_purchasing_id | int | 10 | 0 | N | Y | 理财购买ID | |
2 | user_account | int | 10 | 0 | Y | N | 0 | 用户账号 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | user_phone_number | varchar | 64 | 0 | Y | N | 用户电话 | |
5 | entry_name | varchar | 64 | 0 | Y | N | 项目名称 | |
6 | project_type | varchar | 64 | 0 | Y | N | 项目类型 | |
7 | project_risks | varchar | 64 | 0 | Y | N | 项目风险 | |
8 | project_benefits | varchar | 64 | 0 | Y | N | 项目收益 | |
9 | purchase_date | date | 10 | 0 | Y | N | 购买日期 | |
10 | purchase_amount | int | 10 | 0 | Y | N | 0 | 购买金额 |
11 | purchase_details | text | 65535 | 0 | Y | N | 购买详情 | |
12 | pay_state | varchar | 16 | 0 | N | N | 未支付 | 支付状态 |
13 | pay_type | varchar | 16 | 0 | Y | N | 支付类型: 微信、支付宝、网银 | |
14 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
15 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | financial_sales_id | int | 10 | 0 | N | Y | 理财卖出ID | |
2 | user_account | int | 10 | 0 | Y | N | 0 | 用户账号 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | user_phone_number | varchar | 64 | 0 | Y | N | 用户电话 | |
5 | entry_name | varchar | 64 | 0 | Y | N | 项目名称 | |
6 | project_type | varchar | 64 | 0 | Y | N | 项目类型 | |
7 | project_risks | varchar | 64 | 0 | Y | N | 项目风险 | |
8 | project_benefits | varchar | 64 | 0 | Y | N | 项目收益 | |
9 | purchase_date | date | 10 | 0 | Y | N | 购买日期 | |
10 | purchase_amount | int | 10 | 0 | Y | N | 0 | 购买金额 |
11 | purchase_details | text | 65535 | 0 | Y | N | 购买详情 | |
12 | selling_time | datetime | 19 | 0 | Y | N | 卖出时间 | |
13 | reason_for_sale | text | 65535 | 0 | Y | N | 卖出原因 | |
14 | examine_state | varchar | 16 | 0 | N | N | 未审核 | 审核状态 |
15 | examine_reply | varchar | 16 | 0 | Y | N | 审核回复 | |
16 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
17 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | hits_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | household_expenses_id | int | 10 | 0 | N | Y | 家庭支出ID | |
2 | user_account | int | 10 | 0 | Y | N | 0 | 用户账号 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | user_phone_number | varchar | 64 | 0 | Y | N | 用户电话 | |
5 | expenditure_date | date | 10 | 0 | Y | N | 支出日期 | |
6 | expenditure_type | varchar | 64 | 0 | Y | N | 支出类型 | |
7 | expenditure_amount | int | 10 | 0 | Y | N | 0 | 支出金额 |
8 | other_remarks | text | 65535 | 0 | Y | N | 其他备注 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | household_income_id | int | 10 | 0 | N | Y | 家庭收入ID | |
2 | user_account | int | 10 | 0 | Y | N | 0 | 用户账号 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | user_phone_number | varchar | 64 | 0 | Y | N | 用户电话 | |
5 | revenue_date | date | 10 | 0 | Y | N | 收入日期 | |
6 | income_type | varchar | 64 | 0 | Y | N | 收入类型 | |
7 | income_amount | int | 10 | 0 | Y | N | 0 | 收入金额 |
8 | other_remarks | text | 65535 | 0 | Y | N | 其他备注 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | income_type_id | int | 10 | 0 | N | Y | 收入类型ID | |
2 | income_type | varchar | 64 | 0 | Y | N | 收入类型 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | praise_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | status | bit | 1 | 0 | N | N | 1 | 点赞状态:1为点赞,0已取消 |
表profit_and_loss_situation (盈亏情况)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | profit_and_loss_situation_id | int | 10 | 0 | N | Y | 盈亏情况ID | |
2 | user_account | int | 10 | 0 | Y | N | 0 | 用户账号 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | user_phone_number | varchar | 64 | 0 | Y | N | 用户电话 | |
5 | entry_name | varchar | 64 | 0 | Y | N | 项目名称 | |
6 | project_type | varchar | 64 | 0 | Y | N | 项目类型 | |
7 | purchase_date | date | 10 | 0 | Y | N | 购买日期 | |
8 | purchase_amount | int | 10 | 0 | Y | N | 0 | 购买金额 |
9 | statistical_date | date | 10 | 0 | Y | N | 统计日期 | |
10 | profit_and_loss_amount | varchar | 64 | 0 | Y | N | 盈亏金额 | |
11 | other_remarks | text | 65535 | 0 | Y | N | 其他备注 | |
12 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
13 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | regular_users_id | int | 10 | 0 | N | Y | 普通用户ID | |
2 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
3 | user_phone_number | varchar | 16 | 0 | Y | N | 用户电话 | |
4 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
5 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
6 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | slides_id | int | 10 | 0 | N | Y | 轮播图ID: | |
2 | title | varchar | 64 | 0 | Y | N | 标题: | |
3 | content | varchar | 255 | 0 | Y | N | 内容: | |
4 | url | varchar | 255 | 0 | Y | N | 链接: | |
5 | img | varchar | 255 | 0 | Y | N | 轮播图: | |
6 | hits | int | 10 | 0 | N | N | 0 | 点击量: |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | upload_id | int | 10 | 0 | N | Y | 上传ID | |
2 | name | varchar | 64 | 0 | Y | N | 文件名 | |
3 | path | varchar | 255 | 0 | Y | N | 访问路径 | |
4 | file | varchar | 255 | 0 | Y | N | 文件路径 | |
5 | display | varchar | 255 | 0 | Y | N | 显示顺序 | |
6 | father_id | int | 10 | 0 | Y | N | 0 | 父级ID |
7 | dir | varchar | 255 | 0 | Y | N | 文件夹 | |
8 | type | varchar | 32 | 0 | Y | N | 文件类型 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | user_id | mediumint | 8 | 0 | N | Y | 用户ID:[0,8388607]用户获取其他与用户相关的数据 | |
2 | state | smallint | 5 | 0 | N | N | 1 | 账户状态:[0,10](1可用|2异常|3已冻结|4已注销) |
3 | user_group | varchar | 32 | 0 | Y | N | 所在用户组:[0,32767]决定用户身份和权限 | |
4 | login_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 上次登录时间: |
5 | phone | varchar | 11 | 0 | Y | N | 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时 | |
6 | phone_state | smallint | 5 | 0 | N | N | 0 | 手机认证:[0,1](0未认证|1审核中|2已认证) |
7 | username | varchar | 16 | 0 | N | N | 用户名:[0,16]用户登录时所用的账户名称 | |
8 | nickname | varchar | 16 | 0 | Y | N | 昵称:[0,16] | |
9 | password | varchar | 64 | 0 | N | N | 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成 | |
10 | | varchar | 64 | 0 | Y | N | 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时 | |
11 | email_state | smallint | 5 | 0 | N | N | 0 | 邮箱认证:[0,1](0未认证|1审核中|2已认证) |
12 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
13 | open_id | varchar | 255 | 0 | Y | N | 针对获取用户信息字段 | |
14 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
15 | vip_level | varchar | 255 | 0 | Y | N | 会员等级 | |
16 | vip_discount | double | 11 | 2 | Y | N | 0.00 | 会员折扣 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | group_id | mediumint | 8 | 0 | N | Y | 用户组ID:[0,8388607] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000] |
3 | name | varchar | 16 | 0 | N | N | 名称:[0,16] | |
4 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该用户组的特点或权限范围 | |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | register | smallint | 5 | 0 | Y | N | 0 | 注册位置: |
9 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表wealth_management_projects (理财项目)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | wealth_management_projects_id | int | 10 | 0 | N | Y | 理财项目ID | |
2 | entry_name | varchar | 64 | 0 | Y | N | 项目名称 | |
3 | project_images | varchar | 255 | 0 | Y | N | 项目图片 | |
4 | project_type | varchar | 64 | 0 | Y | N | 项目类型 | |
5 | project_risks | varchar | 64 | 0 | Y | N | 项目风险 | |
6 | project_benefits | varchar | 64 | 0 | Y | N | 项目收益 | |
7 | revenue_ranking | int | 10 | 0 | Y | N | 0 | 收益排名 |
8 | project_details | text | 65535 | 0 | Y | N | 项目详情 | |
9 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
10 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
第五章 系统实现
5.1 前台用户模块的实现
5.1.1 用户首页模块
首页主要分别展示各个模块的最新动态,浏览者可以很清楚地看到不同模块的最新更新内容。并且系统首页每个部分可以跳转到相对应的模块,方便浏览者选择感兴趣的地方。
前端首页载入流程图如下所示。
图5-1 首页载入流程
前端首页如下图所示。
图5-2 首页界面
5.1.2 用户注册模块
当用户点击右上角“注册”按钮的时候,当填写上自己的账号+密码+确认密码+昵称+邮箱+手机号等信息后再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可注册成功。
用户注册流程图如下所示。
图5-3 用户注册流程
用户注册界面展示图如下所示。
图5-4 用户注册界面
注册关键代码如下:
@PostMapping("register")
public Map<String, Object> signUp(HttpServletRequest request) throws IOException {
Map<String, String> query = new HashMap<>();
Map<String,Object> map = service.readBody(request.getReader());
query.put("username",String.valueOf(map.get("username")));
List list = service.selectBaseList(service.select(query, new HashMap<>()));
if (list.size()>0){
return error(30000, "用户已存在");
}
map.put("password",service.encryption(String.valueOf(map.get("password"))));
service.insert(map);
return success(1);
}
5.1.3 用户登录模块
在登录界面中输入用户名+密码,然后选择相应的角色,点击“登录”按钮,系统会在用户数据库表中匹配相应用户的帐户,如果用户名+密码正确,则会登录到系统中每个用户的主管理界面,否则会提示相应的信息,如果是忘记了密码,请返回登录界面。
用户登录流程图如下所示。
图5-5登录流程图
系统登录界面如下所示。
图5-6系统登录界面
登录的逻辑代码如下所示。
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
QueryWrapper wrapper = new QueryWrapper<User>();
Map<String, String> map = new HashMap<>();
5.1.4 个人资料模块
当您完成/注册操作,您就能够更新您的个人资料。您需要确保您的inputname值能够和您所属的实体类型的参数完全对应。当您更新您的个人资料时,您的账号密码应当保持完整,不能出现任何错误。您需要确保您的账号密码是唯一的,才能继续使用。
密码修改流程图如下所示。
图5-7密码修改流程图
密码修改界面如下图所示。
图5-8密码修改界面
5.1.5 评论模块
用户可以发表自己的评论。将页面session中的用户账号userId和发表留言文字框内容传入控制层PinglunAction,调用addPinglun方法,通过PinglunDAOImp向数据库评论区插入,将结果返回plq.Java界面。
评论发布流程图如下图所示。
图5-9评论发布流程图
评论发布操作界面如下图所示。
图5-10评论发布操作界面
5.1.6 理财项目模块
当用户点击家庭理财管理APP中首页的“理财项目”后将会进入到该“理财项目”列表的界面,然后选择想要看的理财项目,点击进入到详细界面,在详细界面可以查看项目风险、项目类型、项目名称、项目图片、项目收益、收益排名、项目详情等信息。可以点击“购买”按钮对理财项目进行购买信息填写,也可以进行点赞、评论和收藏。理财项目详情界面如下图所示。
图5-11理财项目详情界面
理财购买填写界面如下图所示。
图5-12理财购买填写界面
5.1.7 我的模块
当用户点击右上角“我的”这个按钮,会出现子菜单,普通用户可对基本信息、收藏、统计图、家庭支出、家庭收入、理财购买、盈亏情况、理财卖出进行设置管理。用户我的界面如下图所示。
图5-13我的界面
5.2 后台管理子系统模块的实现
5.2.1 系统用户模块
后台管理员在“系统用户”这一菜单中可以对普通用户和管理人员的账号信息进行添加管控。管理员系统用户管理界面如下图所示。
图5-14系统用户管理界面
5.2.2 理财项目管理模块的实现
管理员执行理财项目管理,并可以操作相关内容,例如添加,查看,编辑和删除。通过单击“添加理财项目”,可以通过理财项目添加界面添加详细信息。单击查看字段级别链接以查看有关所选字段级别的信息。然后单击“提交”跳转重返到添加页面。添加成功后的信息会载入到理财项目查询列表中,管理员可进行编辑以及修改。理财项目添加界面如下图所示。
图5-15 理财项目添加界面
5.2.3 系统管理模块
管理员点击“系统管理”菜单可以对系统的轮播图进行管理,查看到系统中的所有轮播图信息,对已经存在的轮播图,管理员可以修改,也可以发布新的信息。
轮播图管理界面如下所示。
图5-16轮播图管理界面
第六章 系统测试
6.1 测试目的
对任何系统而言,测试都是必不可少的环节,测试可以发现系统存在的很多问题,所有的软件上线之前,都应该进行充足的测试之后才能保证上线后不会Bug频发,或者是功能不满足需求等问题的发生。下面分别从单元测试,功能测试和用例测试来对系统进行测试以保证系统的稳定性和可靠性。
6.2 功能测试
下表是系统登录功能测试用例,检测了用户名和密码的不同的输入情况,观察系统的响应情况。得出该功能达到了设计目标。
表6-1 系统登录功能测试用例
功能描述 | 用于系统登录 | |
测试目的 | 检测登录时的合法性检查 | |
测试数据以及操作 | 预期结果 | 实际结果 |
输入的用户名和密码带有非法字符 | 提示用户名或者密码错误 | 与预期结果一致 |
输入的用户名或者密码为空 | 提示用户名或者密码错误 | 与预期结果一致 |
输入的用户名和密码不存在 | 提示用户名或者密码错误 | 与预期结果一致 |
输入正确的用户名和密码 | 登录成功 | 与预期结果一致 |
下表是注册功能测试用例,检测了各种数据的输入情况,观察系统的响应情况。得出该功能达到了设计目标。
表6-2 注册功能测试用例
功能描述 | 用于用户注册 | |
测试目的 | 检测用户注册时的合法性检查 | |
测试数据以及操作 | 预期结果 | 实际结果 |
输入的手机号不合法 | 提示请输入正确的手机号码 | 与预期结果一致 |
输入的字段为空 | 提示必填项不能为空 | 与预期结果一致 |
输入的密码少于6位 | 提示密码必须为6-12位 | 与预期结果一致 |
输入的密码大于12位 | 提示密码必须为6-12位 | 与预期结果一致 |
下表是理财项目管理功能的测试用例,检测了理财项目管理中对理财项目的增加,删除,修改,查询操作是否成功运行。观察系统的响应情况,得出该功能也达到了设计目标,系统运行正确。
前置条件;用户登录系统。
表6-3 理财项目管理的测试用例
功能描述 | 用于理财项目管理 | |
测试目的 | 检测理财项目管理时的各种操作的运行情况 | |
测试数据以及操作 | 预期结果 | 实际结果 |
点击添加理财项目,必填项合法输入,点击保存 | 提示添加成功 | 与预期结果一致 |
点击添加理财项目,必填项输入不合法,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击修改理财项目,必填项修改为空,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击修改理财项目,必填项输入不合法,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击删除理财项目,选择天气预报删除 | 提示删除成功 | 与预期结果一致 |
点击搜索理财项目,输入存在的购买信息 | 查找出理财项目 | 与预期结果一致 |
点击搜索理财项目,输入不存在的购买信息 | 不显示理财项目 | 与预期结果一致 |
6.3 系统测试结果
通过对家庭理财管理APP的调试,能够检测家庭理财管理APP的稳定性,为家庭理财管理APP正式运行、稳定运行提供了可预测性的维护备案。能够帮助使用者熟悉整个家庭理财管理APP,并对家庭理财管理APP可能出现的错误有所了解。本章节提供了部分调试用例及调试日志,可以帮助使用者解决简单的错误问题,也加深了开发者对于此框架下的家庭理财管理APP编写的了解度,为后期开发者顺利完成家庭理财管理APP、发布家庭理财管理APP提供了非常大的帮助。
第七章 总结与展望
在这个设计中,我花了大量的时间去理解系统开发中使用的知识,经过这段时间的努力工作最终完成了系统设计。通过这一阶段的学习,我发现了自己的不足,充分掌握了必要的应用技能,进一步的学习使我充实了自己的知识基础,完成了这个艰巨的任务。当遇到问题时,我很及时的寻求老师的帮助,通过专业的网站和论坛来解决,他们的帮助让我一步一步的成功克服了困难的问题。系统设计过程不容易,你需要不断充实自己,有勇气克服困难。系统开发的一些功能还不完善,需要继续改善后,通过用户体验来修改设计完美的系统,让用户得到更好的体验,我觉得很高兴,因为这是我第一次通过自己的努力实现这个系统,但绝不是我的最后一个,在未来我将努力实现更多的优秀的系统。
在一些编程语言的系统实现中,对词汇表不太熟悉,导致了开发的困难,但是我通过了合适的字典软件来解决这个大问题。由此,我学会了自己的英语缺陷。在那之后,我不断地提高自己的英语知识,这样我就不会有任何未来的工作和生活。毕业设计过程我感觉很深刻,从一开始就不熟悉开发技术,一步一步的使用,接触到文献和信息,不难理解,系统是一次又一次的实现,系统本身对于在线学习是有用的。我从这个设计中获益良多,论文的编写需要有自己的意愿去实现一点,学习生活中所有的问题的勇气,学习的过程就是学习的过程。毕业设计,我学会了将理论知识应用于实践。让我知道该怎么做,我们必须认真对待。勇于克服困难,相信未来,我会做得更好。
参考文献
[1]杨天雨.高职院校“Android软件开发”课程思政建设与实践[J].江苏经贸职业技术学院学报,2024,(01):89-92.DOI:10.16335/j.cnki.issn1672-2604.2024.01.023.
[2]Yu C ,Feng J ,Zheng Z , et al.A lightweight SOD-YOLOv5n model-based winter jujube detection and counting method deployed on Android[J].Computers and Electronics in Agriculture,2024,218108701-.
[3]王斌,李峰,杨慧婷等.Android应用程序漏洞检测方法和工具新进展[J].计算机技术与发展,2024,34(02):9-16.
[4]APKGrab Launches a User-Friendly Platform with Over 60,000 Top Android Apps - No Login, No Ads[J].M2 Presswire,2024,
[5]Ji X .Application of optical motion capture device based on android intelligent platform in sports field auxiliary recognition system[J].Optical and Quantum Electronics,2023,56(3):
[6]杨保山,杨智,陈性元等.Android应用敏感行为与隐私政策一致性分析[J].计算机应用,2024,44(03):788-796.
[7]S. S B ,Anushka D ,Ankit B , et al.‘MrudaTest’: An Android Phone Intervened Platform for Soil Primary Nutrients and pH Detection[J].Communications in Soil Science and Plant Analysis,2023,54(14):2014-2030.
[8]张煜雪.家庭金融理财影响因素分析[J].合作经济与科技,2022,(23):49-51.DOI:10.13665/j.cnki.hzjjykj.2022.23.028.
[9]黄飞.我国家庭金融投资理财现状及趋势研究[J].金融文坛,2022,(11):1-3.
[10]刘勃劭.我国居民家庭投资理财存在的问题与对策[J].投资与合作,2022,(10):31-33.
[11]胡雪宁.试析互联网金融背景下的家庭理财规划策略[J].商讯,2022,(18):71-74.
[12]刘建红.利率下行趋势下老年人家庭理财的思考[J].家庭科技,2022,(03):50-51.
[13]张瑾.基于生命周期的家庭理财规划研究[D].上海财经大学,2021.DOI:10.27296/d.cnki.gshcu.2021.001599.
[14]符青林.家庭理财工具分类及特征分析[J].工程技术研究,2021,6(17):145-147+225.DOI:10.19537/j.cnki.2096-2789.2021.17.061.
[15]王倩若.金融素养对我国居民家庭金融资产配置的影响研究[D].山西财经大学,2021.DOI:10.27283/d.cnki.gsxcc.2021.000253.
[16]杨霄羽.内乡县农村家庭理财问题研究[D].河南工业大学,2021.DOI:10.27791/d.cnki.ghegy.2021.000150.
[17]马自腾,严张凌.基于Android的日常理财通APP的设计与实现[J].信息与电脑(理论版),2020,32(22):107-109.
[18]邓钦文.基于Android平台下家庭理财通软件的设计[J].中国新通信,2020,22(10):84.
[19]王青青,潘东亮.基于Android的大学生旅游理财APP设计[J].软件工程,2020,23(04):34-36+33.DOI:10.19644/j.cnki.issn2096-1472.2020.04.009.
[20]吴小平.财富管理行业发展现状与趋势[J].山东工商学院学报,2020,34(01):9-20.
致谢
这篇文章的完成经历了多个日日夜夜的努力,终于在今天得以完成。这篇文章的创作过程实为不易,但在老师和同学的辛勤帮助下顺利渡过。让我在设计过程中举步维艰时,非常感谢我的导师不耐其烦的帮助我解决问题,给予了我许多指导意见。也感谢所有为我授业解惑的老师!
另外,本文的完成也参考借鉴了许多国内外在Android技术上的著作,如果没有著作原作的辛勤付出和科研成果,我也很难完成本论文。感谢在本论文中关联到的学者们!也感谢Google等公司,感谢他们强大的搜索引擎,让我的资料查阅省事简单。
感谢之余也还有几句话要说,虽大学学习四年,怎奈何本人才疏学浅,本文的完成已为尽力,但文中不免有些不当和错误之处,诚挚真切的请求各位老师对本文的批评改正,感谢百忙之中费心审阅我论文的老师。