SpringBoot+Vue实现前后端分离的心理咨询系统

目录

一、前言介绍

二、系统功能 

三、系统前台模块

3.1系统登录页面

3.2问卷调查页面

3.3心理资讯页面

3.4咨询师信息页面

3.5咨询师详情页面 

3.6减压大本营详情页面 

四、管理员功能模块

4.1站点管理模块

4.2用户管理模块

4.3内容管理模块 

4.4更多管理模块 

五、咨询师功能模块

5.1问卷调查增加页面

5.2预约信息页面

六、普通用户功能模块

6.1预约信息页面 

七、部分核心代码 

7.1问卷调查关键代码

7.2心理咨询管理的关键代码

7.3用户登录的关键代码

一、前言介绍

心理咨询系统主要功能模块包括站点管理、用户管理、内容管理、更多管理、咨询师信息、预约信息、咨询信息、减压大本营、咨询方向等,采取本系统此次设计前端视图界面选择Visual Studio Code来完成,系统功能设计由Java面向对象编程语言实现,系统开发工具选用IDEA,后台数据库为MySQL,项目管理工具选用Navicat,总体的设计框架为最近很方便的springboot框架,实现了本系统的全部功能。本次报告,首先分析了研究的背景、作用、意义,为研究工作的合理性打下了基础。针对心理咨询系统的各项需求以及技术问题进行分析,证明了系统的必要性和技术可行性,然后对设计系统需要使用的技术软件以及设计思想做了基本的介绍,最后来实现心理咨询系统和部署运行使用它。

二、系统功能 

本心理咨询系统主要包括三大功能模块,即管理员、咨询师、用户功能模块。

(1)前台用户:首页、问卷调查、公告消息、心理资讯、咨询师信息、减压大本营、登录注册、我的(我的账户、我的收藏、个人中心、退出)。 

(2)用户后台: 首页、预约信息、咨询信息。

(3)管理员模块:系统中的核心用户是管理员,管理员登录后,通过管理员来管理后台系统。主要功能有:站点管理(轮播图、公告栏),用户管理(管理员、普通用户、咨询师),内容管理(心理资讯、资讯分类、问卷调查),更多管理(咨询师信息、预约信息、咨询信息、减压大本咨询方向)。

(4)咨询师模块:心理资讯、资讯分类、问卷调查、咨询师信息、预约信息、咨询信息、减压大本营。

三、系统前台模块

3.1系统登录页面

3.2问卷调查页面

3.3心理资讯页面

3.4咨询师信息页面

3.5咨询师详情页面 

3.6减压大本营详情页面 

四、管理员功能模块

4.1站点管理模块

4.2用户管理模块

4.3内容管理模块 

4.4更多管理模块 

五、咨询师功能模块

5.1问卷调查增加页面

5.2预约信息页面

六、普通用户功能模块

6.1预约信息页面 

七、部分核心代码 

7.1问卷调查关键代码

  @RequestMapping("/get_obj")
 
    public Map<String, Object> obj(HttpServletRequest request) {
 
        List resultList = service.selectBaseList(service.select(service.readQuery(request), service.readConfig(request)));
 
        if (resultList.size() > 0) {
 
            JSONObject jsonObject = new JSONObject();
 
            jsonObject.put("obj",resultList.get(0));
 
            return success(jsonObject);
 
        } else {
 
            return success(null);
 
        }
 
}

7.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);
 
}
 
    }

7.3用户登录的关键代码

  /**
 
     * 登录

     * @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;
 
        QueryWrapper wrapper = new QueryWrapper<User>();
 
        Map<String, String> map = new HashMap<>();
 
        if(username != null && "".equals(username) == false){
 
            map.put("username", username);
 
            resultList = service.selectBaseList(service.select(map, new HashMap<>()));
 
        }
 
        else if(email != null && "".equals(email) == false){
 
            map.put("email", email);
 
            resultList = service.selectBaseList(service.select(map, new HashMap<>()));
 
        }
 
        else if(phone != null && "".equals(phone) == false){
 
            map.put("phone", phone);
 
            resultList = service.selectBaseList(service.select(map, new HashMap<>()));
 
        }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.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));
 
        if (groupList.size()<1){
 
            return error(30000,"用户组不存在");
 
        }
 
        UserGroup userGroup = (UserGroup) groupList.get(0);
 
        //查询用户审核状态
 
        if (!StringUtils.isEmpty(userGroup.getSourceTable())){
 
            String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());
 
            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, "账号或密码不正确");
 
        }
 
}
 
    public String select(Map<String,String> query,Map<String,String> config){
 
        StringBuffer sql = new StringBuffer("select ");
 
        sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
 
        sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
 
        if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
 
            sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
 
        }
 
        if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
 
            sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
 
        }
 
        if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
 
            int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
 
            int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
 
            sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
 
        }
 
        log.info("[{}] - 查询操作,sql: {}",table,sql);
 
        return sql.toString();
 
}
 
    public List selectBaseList(String select) {
 
        List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);

        List<E> list = new ArrayList<>();
 
        for (Map<String,Object> map:mapList) {
 
            list.add(JSON.parseObject(JSON.toJSONString(map),eClass));
 
        }
 
        return list;
 
}

 

  此源码非开源,2600多套源码可扫码添加微信进行咨询!

  • 18
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值