案例024:基于微信小程序的汽车保养系统

文末获取源码

开发语言:Java

框架:SSM

JDK版本:JDK1.8

数据库:mysql 5.7

开发软件:eclipse/myeclipse/idea

Maven包:Maven3.5.4

小程序框架:uniapp

小程序开发软件:HBuilder X

小程序运行软件:微信开发者

目录

前言

系统展示

管理员功能实现

门店信息管理

员工信息管理

保养信息管理

已支付订单

配件信息管理

用户功能实现

门店信息

保养信息

配件信息

购物车

我的订单

代码实现

登录功能实现代码

注册功能实现代码

密码重置功能实现代码

修改信息功能实现代码

删除信息功能实现代码

保存信息功能实现代码


前言

由于APP软件在开发以及运营上面所需成本较高,而用户手机需要安装各种APP软件,因此占用用户过多的手机存储空间,导致用户手机运行缓慢,体验度比较差,进而导致用户会卸载非必要的APP,倒逼管理者必须改变运营策略。随着微信小程序的出现,解决了用户非独立APP不可访问内容的痛点,所以很多APP软件都转向微信小程序。本次课题就运用了微信小程序技术开发一个汽车保养系统小程序。

汽车保养系统小程序借助微信开发者工具开发用户前端,使用SSM框架和Java语言开发管理员后台,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,其管理员管理门店和其对应的员工,管理保养信息和汽车配件信息,管理各种状态的订单。用户购买并支付汽车保养产品和汽车配件,评论门店和保养产品以及汽车配件,管理购物车和订单。

总之,汽车保养系统小程序可以更加方便用户购买汽车保养产品以及汽车配件。


系统展示

管理员功能实现

门店信息管理

管理员进入指定功能操作区之后可以管理门店信息。其页面见下图。管理员增删改查门店信息,查看用户对门店的评论。

员工信息管理

管理员进入指定功能操作区之后可以管理员工。其页面见下图。管理员增删改查员工信息,查看员工联系方式以及其所属门店。

保养信息管理

管理员进入指定功能操作区之后可以管理保养信息。其页面见下图。管理员查看用户的评论,增删改查保养信息。

已支付订单

管理员进入指定功能操作区之后可以管理订单。其页面见下图。管理员查看所有已支付订单,然后通过发货按钮对订单执行发货。

配件信息管理

管理员进入指定功能操作区之后可以管理配件信息。其页面见下图。管理员维护配件信息,查看用户对配件的评论。

用户功能实现

门店信息

用户进入指定功能操作区之后可以查看门店介绍。其页面见下图。用户点击红色五角星收藏门店,可以发布有关门店的评论。

保养信息

用户进入指定功能操作区之后可以查看汽车保养信息。其页面见下图。用户订购保养产品或加入购物车,可以在本页面评论汽车保养信息。

配件信息

用户进入指定功能操作区之后可以查看配件。其页面见下图。用户购买配件可以通过购物车下单,也能在本页面直接订购。

购物车

用户进入指定功能操作区之后可以管理购物车。其页面见下图。用户编辑购物车里面的物品的数量,然后下单支付。

我的订单

用户进入指定功能操作区之后可以管理我的订单。其页面见下图。用户查看已支付订单,可以取消订单。


代码实现

登录功能实现代码

java 复制代码
@IgnoreAuth
	@PostMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}

注册功能实现代码

java 复制代码
@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }

密码重置功能实现代码

java 复制代码
@IgnoreAuth
	@RequestMapping(value = "/resetPass")
    public R resetPass(String username, HttpServletRequest request){
    	UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
    	if(user==null) {
    		return R.error("账号不存在");
    	}
    	user.setPassword("123456");
        userService.update(user,null);
        return R.ok("密码已重置为:123456");
    }

修改信息功能实现代码

java 复制代码
 @RequestMapping("/update")
    public R update(@RequestBody UserEntity user){
//        ValidatorUtils.validateEntity(user);
    	UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
    	if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
    		return R.error("用户名已存在。");
    	}
        userService.updateById(user);//全部更新
        return R.ok();
    }

删除信息功能实现代码

java 复制代码
@RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        userService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }

保存信息功能实现代码

java 复制代码
@PostMapping("/save")
    public R save(@RequestBody UserEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }
相关推荐
万邦科技Lafite4 分钟前
一键获取京东商品评论信息,item_reviewAPI接口指南
java·服务器·数据库·开放api·淘宝开放平台·京东开放平台
indexsunny14 分钟前
互联网大厂Java面试实战:从Spring Boot到微服务架构的技术问答解析
java·spring boot·redis·微服务·kafka·jwt·flyway
蓁蓁啊18 分钟前
C/C++编译链接全解析——gcc/g++与ld链接器使用误区
java·c语言·开发语言·c++·物联网
sheji341621 分钟前
【开题答辩全过程】以 基于SpringBoot的疗养院管理系统的设计与实现为例,包含答辩的问题和答案
java·spring boot·后端
盒马coding26 分钟前
深度解密MySQL2PG工具MySQL至PostgreSQL语法全景拆解过程
数据库·mysql·postgresql
tb_first34 分钟前
万字超详细苍穹外卖学习笔记2
java·jvm·数据库·spring·tomcat·maven
Nandeska38 分钟前
13、MySQL半同步复制示例
数据库·mysql
短剑重铸之日44 分钟前
《设计模式》第六篇:装饰器模式
java·后端·设计模式·装饰器模式
液态不合群1 小时前
【面试题】MySQL 中 count(*)、count(1) 和 count(字段名) 有什么区别?
android·数据库·mysql