文末获取源码
开发语言:Java
使用框架:spring boot
前端技术:JavaScript、Vue 、css3
开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code
数据库:MySQL 5.7/8.0
数据库管理工具:phpstudy/Navicat
JDK版本:jdk1.8
Maven:apache-maven 3.8.1-bin
目录
一、前言介绍
二、系统功能
三、前台用户功能
3.1用户首页模块
3.2公司动态模块
3.3家政人员列表模块
3.4服务项目模块
3.5保洁常识模块
四、管理员功能模块
4.1后台首页模块
4.2家政人员管理模块
4.3服务项目管理模块
4.4订单报表管理模块
4.5用户预约管理模块
五、部分核心代码
5.1家政人员列表列表关键代码
5.2服务项目关键代码
5.3服务项目管理关键代码
5.4用户预约关键代码
5.5用户登录的逻辑代码
系统功能设计由Java面向对象编程语言实现,系统开发工具选用IDEA,后台数据库为MySQL,项目管理工具选用Maven,总体的设计框架为最近很方便的Spring Boot框架,实现了本系统的全部功能。 通过使用该平台,可以让家政服务的工作实现简易化、系统化、自动化、规范化与智能化,从而能够提高家政服务行业的管理效率。
家政服务平台的主要功能包括:轮播图、公告栏、管理员、普通用户、家政用户、在线交流、论坛分类、新闻列表、新闻分类列表、订单状态、家政人员、类型管理、服务项目、用户预约、订单报表、核酸检测管理、保洁常识管理等模块。本系统代码的复用率高,系统维护代价小,具有方便、灵活、高效等特征。
本家政服务平台主要包括三大功能模块,即用户功能模块、家政用户功能模块和管理员功能模块。
(1)管理员模块:首页、站点内容(轮播图、公告栏)系统用户(管理员、普通用户、家政用户)、公共内容(在线交流、论坛分类、新闻列表、新闻分类列表)、模块管理(订单状态、家政人员、类型管理、服务项目、用户预约、订单报表、核酸检测管理、保洁常识管理)等功能。
(2)普通用户:首页、在线交流、公告栏、公司动态、家政人员、服务项目、保洁常识、我的(我的账户、我的收藏、退出)。
用户可以进行首页、公告消息、在线交流、公司动态、家政人员你、服务项目、保洁常识等功能模块的查看与操作。
家政人员列表信息页面,用户可以进行家政人员信息查询操作。
服务项目页面可以进行服务项目展示(项目名称、项目类型、服务详情、项目海报、项目价格)等信息,可以进行项目信息搜索操作。
在服务项目列表页面可以编辑项目名称、项目类型、项目价格、上门时间等内容,并可根据需要进行修改或删除操作。
在订单报表页面可以对订单报表信息(总计收入、项目名称、预约次数)进行管理。并可根据需要进行修改或删除操作。
在用户预约页面可以对具体信息(项目名称、项目类型、服务价格、预约时间、订单状态、服务人员)进行管理。并可根据需要进行修改或删除操作,如图。
@PostMapping("/add")
@Transactional
public Map add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
@Transactional
public Map addMap(Map map){
service.insert(map);
return success(1);
}
public Map readBody(BufferedReader reader){
BufferedReader br = null;
StringBuilder sb = new StringBuilder("");
try{
br = reader;
String str;
while ((str = br.readLine()) != null){
sb.append(str);
}
br.close();
String json = sb.toString();
return JSONObject.parseObject(json, Map.class);
}catch (IOException e){
e.printStackTrace();
}finally{
if (null != br){
try{
br.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
return null;
}
public void insert(Map body){
StringBuffer sql = new StringBuffer("INSERT INTO ");
sql.append("`").append(table).append("`").append(" (");
for (Map.Entry entry:body.entrySet()){
sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
}
sql.deleteCharAt(sql.length()-1);
sql.append(") VALUES (");
for (Map.Entry entry:body.entrySet()){
Object value = entry.getValue();
if (value instanceof String){
sql.append("'").append(entry.getValue()).append("'").append(",");
}else {
sql.append(entry.getValue()).append(",");
}
}
sql.deleteCharAt(sql.length() - 1);
sql.append(")");
log.info("[{}] - 插入操作:{}",table,sql);
Query query = runCountSql(sql.toString());
query.executeUpdate();
}
@RequestMapping("/get_list")
public Map getList(HttpServletRequest request) {
Map map = service.selectToPage(service.readQuery(request), service.readConfig(request));
return success(map);
}
@RequestMapping(value = {"/avg_group", "/avg"})
public Map avg(HttpServletRequest request) {
Query count = service.avg(service.readQuery(request), service.readConfig(request));
return success(count.getResultList());
}
@RequestMapping("/get_list")
public Map getList(HttpServletRequest request) {
Map map = service.selectToPage(service.readQuery(request), service.readConfig(request));
return success(map);
}
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@PostMapping("login")
public Map login(@RequestBody Map 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;
Map map = new HashMap<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.select(map, new HashMap<>()).getResultList();
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.select(map, new HashMap<>()).getResultList();
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
String res = String.valueOf(service.runCountSql(sql).getSingleResult());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
tokenService.save(accessToken);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}