微信小程序 uniapp网络记账设计个人理财系统

文章目录

项目介绍

aa账簿 (自动编号、用户id、用户账号、备注、登记时间、消费类型、创建时间、消费金额);

配置文件 (自动编号、配置参数值、配置参数名称);

当日收入 (自动编号、用户账号、备注、用户id、登记时间、创建时间、奖金、总收入、其他、工资);

当日支出 (自动编号、衣服、总支出、其他、备注、餐饮、旅游、创建时间、登记时间、交通、用户账号、用户id、日用品);

家庭账簿 (自动编号、当日总支出、当日总收入、登记时间、当日结余、创建时间、用户账号、用户id、备注);

理财投资 (自动编号、登记时间、创建时间、备注、投资金额、投资项目、用户id、用户账号、当日状况);

系统公告 (自动编号、创建时间、标题、内容、图片、简介);

token表 (自动编号、密码、新增时间、角色、用户名、过期时间、用户id、表名);

用户表 (自动编号、角色、新增时间、密码、用户名);

消费类型 (自动编号、消费类型、创建时间);

用户 (自动编号、创建时间、密码、用户姓名、联系电话、电子邮箱、用户账号、性别、年龄);

本系统的设计与实现共包含11个表:分别是aa账簿信息表,配置文件信息表,当日收入信息表,当日支出信息表,家庭账簿信息表,理财投资信息表,系统公告信息表,token表信息表,用户表信息表,消费类型信息表,用户信息表,

具体实现截图




技术介绍

数据库工具:Navicat/SQLyog等都可以 前端开发框架:vue.js 数据库 mysql 版本不限 小程序端运行软件 微信开发者工具/hbuiderx 后端语言支持以下技术栈: 1 java(SSM/springboot)-idea/eclipse 2.Nodejs+Vue.js -vscode 3.python(flask/django)--pycharm/vscode 4.php(thinkphp/laravel)-hbuilderx MySQL使用的SQL语言是访问数据库较为常用的标准化语言,它可以通过一些简单的操作从而实现对复杂的功能进行查询,并且具有良好的可扩展性和可维护性等优点,MySQL软件非常的适合用作中小型网站发展的网站数据库,因为它的体积小,速度快,总体拥有成本低,尤其是开放源码。

mvc设计模式

MVC设计模式将应用程序分为Model、View和Controller三个核心部分,以组织和管理代码。Model负责数据和业务逻辑,View展示数据给用户并接收用户输入,Controller协调Model和View之间的交互[3]。通过明确各组件职责、降低耦合度,MVC提高了代码可读性和可维护性,也增强了系统扩展性和重用性[4]。

MVC设计模式的分离机制降低了系统复杂度,便于替换和重用组件,提高了团队合作效率[5]。这种经典的软件架构模式在Web开发、桌面应用程序等领域广泛应用,有助于构建灵活、可维护和可扩展的软件系统[6]。

小程序框架以及目录结构介绍

小程序自身分为两个主要部分独立运行:view 模块和 service 模块。在开发者工具中,它们独立运行于不同的 webivew tag 中。

view 模块负责前端界面显示,它由 wxml 和 wxss 转换后代码以及微信提供相关辅助模块组成。 一个 view 模块对应一个 页面, 小程序支持同时多个 view 存在。

service 模块负责后台逻辑,它由 js 代码以及微信提供的相关辅助模块组成。 一个应用只有一个 service 进程,它同样也是一个页面。它在程序生命周期内后台运行,service 模块通过与 view 模块实现不同但接口格式一样的微信JSBridge 对象跟后台通信。

小程序需要使用微信开发者工具来进行开发,同时最常用的参考文档是微信小程序官方文档。在开发者工具中包含了模拟器、调试器等,内容很全面。也可以用云模式来在腾讯云进行后台开发。使得开发者不用搭建数据库等,专注于逻辑设计,简化后台设计,另外为了更好的展示小程序可以用一些工具插件,例如wx-charts和echarts等,这两个都可用于图形化展示统计数据。

错误处理和异常处理

在 系统中,设计了一个健壮的错误处理和异常处理策略。系统会捕获可能发生的错误和异常情况,并提供相应的处理和反馈机制。

系统将采用适宜的异常类别来描述各种类型的错误和异常状况,并通过异常处理策略去捕获和应对这些异常。在处理异常时,系统会提供相关的错误数据和日志记录,以协助开发者和管理者进行问题诊断和解决。此外,系统还会向用户提供友好的错误提示,以确保用户能够理解问题并采取适当的行动。

java类核心代码部分展示

csharp 复制代码
@RestController
@RequestMapping("/yuangong")
public class YuangongController {
    @Autowired
    private YuangongService yuangongService;
	@Autowired
	private TokenService tokenService;
		/**
     * 获取用户的session用户信息
     */
    @RequestMapping("/session")
    public R getCurrUser(HttpServletRequest request){
    	Long id = (Long)request.getSession().getAttribute("userId");
        YuangongEntity user = yuangongService.selectById(id);
        return R.ok().put("data", user);
    }
	/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		YuangongEntity user = yuangongService.selectOne(new EntityWrapper<YuangongEntity>().eq("yuangonggonghao", username));
		if(user==null || !user.getMima().equals(password)) {
			return R.error("账号或密码不正确");
		}
		
		String token = tokenService.generateToken(user.getId(), username,"yuangong",  "员工" );
		return R.ok().put("token", token);
	}
	       /**
     * 密码重置
     */
    @IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	YuangongEntity user = yuangongService.selectOne(new EntityWrapper<YuangongEntity>().eq("yuangonggonghao", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
        user.setMima("123456");
        yuangongService.updateById(user);
        return R.ok("密码已重置为:123456");
    }
	/**
     * 注册
     */
	@IgnoreAuth
    @RequestMapping("/register")
    public R register(@RequestBody YuangongEntity yuangong){
    	//ValidatorUtils.validateEntity(yuangong);
    	YuangongEntity user = yuangongService.selectOne(new EntityWrapper<YuangongEntity>().eq("yuangonggonghao", yuangong.getYuangonggonghao()));
		if(user!=null) {
			return R.error("注册用户已存在");
		}
		Long uId = new Date().getTime();
		yuangong.setId(uId);
        yuangongService.insert(yuangong);
        return R.ok();
    }

	/**
	 * 退出
	 */
	@RequestMapping("/logout")
	public R logout(HttpServletRequest request) {
		request.getSession().invalidate();
		return R.ok("退出成功");
	}
	

 

详细视频演示

请联系我获取更详细的演示视频

源码获取

需要成品,加我们的时候,记得把页面截图发下我,方便查找相应的源代码。
文章最下方名片联系我即可~

相关推荐
耶啵奶膘1 小时前
uniapp+vue2全局监听退出小程序清除缓存
小程序·uni-app
中云DDoS CC防护蔡蔡3 小时前
微信小程序被攻击怎么选择高防产品
服务器·网络安全·微信小程序·小程序·ddos
井眼7 小时前
微信小程序-prettier 格式化
微信小程序·小程序
我开心就好o8 小时前
uniapp点左上角返回键, 重复来回跳转的问题 解决方案
前端·javascript·uni-app
Random_index8 小时前
#Uniapp篇:支持纯血鸿蒙&发布&适配&UIUI
uni-app·harmonyos
qq_17448285759 小时前
springboot基于微信小程序的旧衣回收系统的设计与实现
spring boot·后端·微信小程序
wqq_9922502779 小时前
springboot基于微信小程序的食堂预约点餐系统
数据库·微信小程序·小程序
初遇你时动了情16 小时前
uniapp 城市选择插件
开发语言·javascript·uni-app
licy__16 小时前
微信小程序登录注册页面设计(小程序项目)
微信小程序·小程序
小小黑00718 小时前
uniapp+vue3+ts H5端使用Quill富文本插件以及解决上传图片反显的问题
uni-app·vue