文末获取源码
开发语言: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
目录
系统功能设计由Java面向对象编程语言实现,系统开发工具选用IDEA,后台数据库为MySQL,项目管理工具选用Maven,总体的设计框架为最近很方便的Spring Boot框架,实现了本系统的全部功能。 通过使用该平台,可以让家政服务的工作实现简易化、系统化、自动化、规范化与智能化,从而能够提高家政服务行业的管理效率。
家政服务平台的主要功能包括:轮播图、公告栏、管理员、普通用户、家政用户、在线交流、论坛分类、新闻列表、新闻分类列表、订单状态、家政人员、类型管理、服务项目、用户预约、订单报表、核酸检测管理、保洁常识管理等模块。本系统代码的复用率高,系统维护代价小,具有方便、灵活、高效等特征。
本家政服务平台主要包括三大功能模块,即用户功能模块、家政用户功能模块和管理员功能模块。
(1)管理员模块:首页、站点内容(轮播图、公告栏)系统用户(管理员、普通用户、家政用户)、公共内容(在线交流、论坛分类、新闻列表、新闻分类列表)、模块管理(订单状态、家政人员、类型管理、服务项目、用户预约、订单报表、核酸检测管理、保洁常识管理)等功能。
(2)普通用户:首页、在线交流、公告栏、公司动态、家政人员、服务项目、保洁常识、我的(我的账户、我的收藏、退出)。
用户可以进行首页、公告消息、在线交流、公司动态、家政人员你、服务项目、保洁常识等功能模块的查看与操作。


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

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




在服务项目列表页面可以编辑项目名称、项目类型、项目价格、上门时间等内容,并可根据需要进行修改或删除操作。
在订单报表页面可以对订单报表信息(总计收入、项目名称、预约次数)进行管理。并可根据需要进行修改或删除操作。
在用户预约页面可以对具体信息(项目名称、项目类型、服务价格、预约时间、订单状态、服务人员)进行管理。并可根据需要进行修改或删除操作,如图。

- @PostMapping("/add")
-
- @Transactional
-
- public Map<String, Object> add(HttpServletRequest request) throws IOException {
-
- service.insert(service.readBody(request.getReader()));
-
- return success(1);
-
- }
-
- @Transactional
-
- public Map<String, Object> addMap(Map<String,Object> map){
-
- service.insert(map);
-
- return success(1);
-
- }
-
- public Map<String,Object> 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<String,Object> body){
-
- StringBuffer sql = new StringBuffer("INSERT INTO ");
-
- sql.append("`").append(table).append("`").append(" (");
-
- for (Map.Entry<String,Object> entry:body.entrySet()){
-
- sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
-
- }
-
- sql.deleteCharAt(sql.length()-1);
-
- sql.append(") VALUES (");
-
- for (Map.Entry<String,Object> 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<String, Object> getList(HttpServletRequest request) {
-
- Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
-
- return success(map);
-
- }
- @RequestMapping(value = {"/avg_group", "/avg"})
-
- public Map<String, Object> avg(HttpServletRequest request) {
-
- Query count = service.avg(service.readQuery(request), service.readConfig(request));
-
- return success(count.getResultList());
-
- }
- @RequestMapping("/get_list")
-
- public Map<String, Object> getList(HttpServletRequest request) {
-
- Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
-
- return success(map);
-
- }
- /**
-
- * 登录
- * @param data
- * @param httpServletRequest
- * @return
- */
- @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;
-
- Map<String, String> 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<String, String> 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, "账号或密码不正确");
-
- }