• SpringBoot+Vue实现前后端分离的家政服务平台


    文末获取源码

    开发语言: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)普通用户:首页、在线交流、公告栏、公司动态、家政人员、服务项目、保洁常识、我的(我的账户、我的收藏、退出)。

    三、前台用户功能

    3.1用户首页模块

    用户可以进行首页、公告消息、在线交流、公司动态、家政人员你、服务项目、保洁常识等功能模块的查看与操作。

    3.2公司动态模块

    3.3家政人员列表模块

    家政人员列表信息页面,用户可以进行家政人员信息查询操作。

    3.4服务项目模块

    服务项目页面可以进行服务项目展示(项目名称、项目类型、服务详情、项目海报、项目价格)等信息,可以进行项目信息搜索操作。

    3.5保洁常识模块

    四、管理员功能模块

    4.1后台首页模块

    4.2家政人员管理模块

    4.3服务项目管理模块

    在服务项目列表页面可以编辑项目名称、项目类型、项目价格、上门时间等内容,并可根据需要进行修改或删除操作。

    4.4订单报表管理模块

    在订单报表页面可以对订单报表信息(总计收入、项目名称、预约次数)进行管理。并可根据需要进行修改或删除操作。

    4.5用户预约管理模块

    在用户预约页面可以对具体信息(项目名称、项目类型、服务价格、预约时间、订单状态、服务人员)进行管理。并可根据需要进行修改或删除操作,如图。

    五、部分核心代码

    5.1家政人员列表列表关键代码

    1. @PostMapping("/add")
    2. @Transactional
    3. public Map<String, Object> add(HttpServletRequest request) throws IOException {
    4. service.insert(service.readBody(request.getReader()));
    5. return success(1);
    6. }
    7. @Transactional
    8. public Map<String, Object> addMap(Map<String,Object> map){
    9. service.insert(map);
    10. return success(1);
    11. }
    12. public Map<String,Object> readBody(BufferedReader reader){
    13. BufferedReader br = null;
    14. StringBuilder sb = new StringBuilder("");
    15. try{
    16. br = reader;
    17. String str;
    18. while ((str = br.readLine()) != null){
    19. sb.append(str);
    20. }
    21. br.close();
    22. String json = sb.toString();
    23. return JSONObject.parseObject(json, Map.class);
    24. }catch (IOException e){
    25. e.printStackTrace();
    26. }finally{
    27. if (null != br){
    28. try{
    29. br.close();
    30. }catch (IOException e){
    31. e.printStackTrace();
    32. }
    33. }
    34. }
    35. return null;
    36. }
    37. public void insert(Map<String,Object> body){
    38. StringBuffer sql = new StringBuffer("INSERT INTO ");
    39. sql.append("`").append(table).append("`").append(" (");
    40. for (Map.Entry<String,Object> entry:body.entrySet()){
    41. sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
    42. }
    43. sql.deleteCharAt(sql.length()-1);
    44. sql.append(") VALUES (");
    45. for (Map.Entry<String,Object> entry:body.entrySet()){
    46. Object value = entry.getValue();
    47. if (value instanceof String){
    48. sql.append("'").append(entry.getValue()).append("'").append(",");
    49. }else {
    50. sql.append(entry.getValue()).append(",");
    51. }
    52. }
    53. sql.deleteCharAt(sql.length() - 1);
    54. sql.append(")");
    55. log.info("[{}] - 插入操作:{}",table,sql);
    56. Query query = runCountSql(sql.toString());
    57. query.executeUpdate();
    58. }

    5.2服务项目关键代码

    1. @RequestMapping("/get_list")
    2. public Map<String, Object> getList(HttpServletRequest request) {
    3. Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
    4. return success(map);
    5. }

    5.3服务项目管理关键代码

    1. @RequestMapping(value = {"/avg_group", "/avg"})
    2. public Map<String, Object> avg(HttpServletRequest request) {
    3. Query count = service.avg(service.readQuery(request), service.readConfig(request));
    4. return success(count.getResultList());
    5. }

    5.4用户预约关键代码

    1. @RequestMapping("/get_list")
    2. public Map<String, Object> getList(HttpServletRequest request) {
    3. Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
    4. return success(map);
    5. }

    5.5用户登录的逻辑代码

    1. /**
    2. * 登录
    3. * @param data
    4. * @param httpServletRequest
    5. * @return
    6. */
    7. @PostMapping("login")
    8. public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
    9. log.info("[执行登录接口]");
    10. String username = data.get("username");
    11. String email = data.get("email");
    12. String phone = data.get("phone");
    13. String password = data.get("password");
    14. List resultList = null;
    15. Map<String, String> map = new HashMap<>();
    16. if(username != null && "".equals(username) == false){
    17. map.put("username", username);
    18. resultList = service.select(map, new HashMap<>()).getResultList();
    19. }
    20. else if(email != null && "".equals(email) == false){
    21. map.put("email", email);
    22. resultList = service.select(map, new HashMap<>()).getResultList();
    23. }
    24. else if(phone != null && "".equals(phone) == false){
    25. map.put("phone", phone);
    26. resultList = service.select(map, new HashMap<>()).getResultList();
    27. }else{
    28. return error(30000, "账号或密码不能为空");
    29. }
    30. if (resultList == null || password == null) {
    31. return error(30000, "账号或密码不能为空");
    32. }
    33. //判断是否有这个用户
    34. if (resultList.size()<=0){
    35. return error(30000,"用户不存在");
    36. }
    37. User byUsername = (User) resultList.get(0);
    38. Map<String, String> groupMap = new HashMap<>();
    39. groupMap.put("name",byUsername.getUserGroup());
    40. List groupList = userGroupService.select(groupMap, new HashMap<>()).getResultList();
    41. if (groupList.size()<1){
    42. return error(30000,"用户组不存在");
    43. }
    44. UserGroup userGroup = (UserGroup) groupList.get(0);
    45. //查询用户审核状态
    46. if (!StringUtils.isEmpty(userGroup.getSourceTable())){
    47. String sql = "select examine_state from "+ userGroup.getSourceTable() +" WHERE user_id = " + byUsername.getUserId();
    48. String res = String.valueOf(service.runCountSql(sql).getSingleResult());
    49. if (res==null){
    50. return error(30000,"用户不存在");
    51. }
    52. if (!res.equals("已通过")){
    53. return error(30000,"该用户审核未通过");
    54. }
    55. }
    56. //查询用户状态
    57. if (byUsername.getState()!=1){
    58. return error(30000,"用户非可用状态,不能登录");
    59. }
    60. String md5password = service.encryption(password);
    61. if (byUsername.getPassword().equals(md5password)) {
    62. // 存储Token到数据库
    63. AccessToken accessToken = new AccessToken();
    64. accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
    65. accessToken.setUser_id(byUsername.getUserId());
    66. tokenService.save(accessToken);
    67. // 返回用户信息
    68. JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
    69. user.put("token", accessToken.getToken());
    70. JSONObject ret = new JSONObject();
    71. ret.put("obj",user);
    72. return success(ret);
    73. } else {
    74. return error(30000, "账号或密码不正确");
    75. }
  • 相关阅读:
    47. 全排列 II
    [附源码]java毕业设计医院档案管理系统
    Node.js精进(1)——模块化
    (八)Java算法:堆排序(详细图解)
    云服务器部署Neo4j
    小程序 swiper滑动 层叠滑动效果
    什么是操作系统?
    linux-任务计划和日志管理
    金融日 | 看金融机构数据安全建设典型案例
    【ElfBoard】基于 Linux 的智能家居小项目
  • 原文地址:https://blog.csdn.net/m0_49113107/article/details/127549221