首页 > 编程语言 >基于SpringBoot+Vue的社团管理系统设计与实现毕设(文档+源码)

基于SpringBoot+Vue的社团管理系统设计与实现毕设(文档+源码)

时间:2024-10-31 19:17:00浏览次数:7  
标签:Vue return SpringBoot huodongShenhe request 源码 role id view

        

目录

一、项目介绍

二、开发环境

三、功能介绍

四、核心代码

五、效果图

六、源码获取:


        大家好呀,我是一个混迹在java圈的码农。今天要和大家分享的是 一款基于SpringBoot+Vue的社团管理系统,项目源码请点击文章末尾联系我哦~目前有各类成品 毕设 JavaWeb  SSM SpringBoot等等项目框架,源码丰富,欢迎咨询。 

一、项目介绍

互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱,出错率高,信息安全性差,劳动强度大,费时费力等问题,采用社团管理系统可以有效管理,使信息管理能够更加科学和规范。

社团管理系统在Eclipse环境中,使用Java语言进行编码,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,其管理员增删改查社团信息和社团信息资料,审核社团预订信息。总之,社团管理系统集中管理信息,有着保密性强,效率高,存储空间大,成本低等诸多优点。它可以降低信息管理成本,实现信息管理计算机化。

关键词:社团管理系统;Java语言;Mysql

二、开发环境

开发系统:Windows
JDK版本:Java JDK1.8(推荐)
开发工具:IDEA/MyEclipse(推荐IDEA)
数据库版本: mysql8.0(推荐)
数据库可视化工具: navicat
服务器:SpringBoot自带 apache tomcat
框架:springboot,vue

三、功能介绍

        生信息管理页面,此页面提供给管理员的功能有:学生信息的查询管理,可以删除学生信息、修改学生信息、新增学生信息,还进行了对用户名称的模糊查询的条件。团信息管理页面,此页面提供给管理员的功能有:查看已发布的社团信息数据,修改社团信息,社团信息作废,即可删除,还进行了对社团信息名称的模糊查询 社团信息信息的类型查询等等一些条件。

        团长信息管理页面,此页面提供给管理员的功能有:根据团长信息进行条件查询,还可以对团长信息进行新增、修改、查询操作等等。公告信息管理页面,此页面提供给管理员的功能有:根据公告信息进行新增、修改、查询操作等等。

四、核心代码


/**
 * 活动审核
 * 后端接口
 * @author
 * @email
*/
@RestController
@Controller
@RequestMapping("/huodongShenhe")
public class HuodongShenheController {
    private static final Logger logger = LoggerFactory.getLogger(HuodongShenheController.class);

    @Autowired
    private HuodongShenheService huodongShenheService;


    @Autowired
    private TokenService tokenService;
    @Autowired
    private DictionaryService dictionaryService;

    //级联表service
    @Autowired
    private HuodongService huodongService;
    @Autowired
    private YonghuService yonghuService;

    @Autowired
    private TuanzhangService tuanzhangService;


    /**
    * 后端列表
    */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){
        logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(StringUtil.isEmpty(role))
            return R.error(511,"权限为空");
        else if("学生".equals(role))
            params.put("yonghuId",request.getSession().getAttribute("userId"));
        else if("团长".equals(role))
            params.put("tuanzhangId",request.getSession().getAttribute("userId"));
        if(params.get("orderBy")==null || params.get("orderBy")==""){
            params.put("orderBy","id");
        }
        PageUtils page = huodongShenheService.queryPage(params);

        //字典表数据转换
        List<HuodongShenheView> list =(List<HuodongShenheView>)page.getList();
        for(HuodongShenheView c:list){
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(c, request);
        }
        return R.ok().put("data", page);
    }

    /**
    * 后端详情
    */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id, HttpServletRequest request){
        logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
        HuodongShenheEntity huodongShenhe = huodongShenheService.selectById(id);
        if(huodongShenhe !=null){
            //entity转view
            HuodongShenheView view = new HuodongShenheView();
            BeanUtils.copyProperties( huodongShenhe , view );//把实体数据重构到view中

                //级联表
                HuodongEntity huodong = huodongService.selectById(huodongShenhe.getHuodongId());
                if(huodong != null){
                    BeanUtils.copyProperties( huodong , view ,new String[]{ "id", "createTime", "insertTime", "updateTime"});//把级联的数据添加到view中,并排除id和创建时间字段
                    view.setHuodongId(huodong.getId());
                }
                //级联表
                YonghuEntity yonghu = yonghuService.selectById(huodongShenhe.getYonghuId());
                if(yonghu != null){
                    BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createTime", "insertTime", "updateTime"});//把级联的数据添加到view中,并排除id和创建时间字段
                    view.setYonghuId(yonghu.getId());
                }
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(view, request);
            return R.ok().put("data", view);
        }else {
            return R.error(511,"查不到数据");
        }

    }

    /**
    * 后端保存
    */
    @RequestMapping("/save")
    public R save(@RequestBody HuodongShenheEntity huodongShenhe, HttpServletRequest request){
        logger.debug("save方法:,,Controller:{},,huodongShenhe:{}",this.getClass().getName(),huodongShenhe.toString());

        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(StringUtil.isEmpty(role))
            return R.error(511,"权限为空");
        else if("学生".equals(role))
            huodongShenhe.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));

        Wrapper<HuodongShenheEntity> queryWrapper = new EntityWrapper<HuodongShenheEntity>()
            .eq("huodong_id", huodongShenhe.getHuodongId())
            .eq("yonghu_id", huodongShenhe.getYonghuId())
            .eq("huodong_shenhe_yesno_types", huodongShenhe.getHuodongShenheYesnoTypes())
            ;

        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        HuodongShenheEntity huodongShenheEntity = huodongShenheService.selectOne(queryWrapper);
        if(huodongShenheEntity==null){
            huodongShenhe.setHuodongShenheYesnoTypes(1);
            huodongShenhe.setCreateTime(new Date());
            huodongShenheService.insert(huodongShenhe);
            return R.ok();
        }else {
            return R.error(511,"请不要重复申请");
        }
    }

    /**
    * 后端修改
    */
    @RequestMapping("/update")
    public R update(@RequestBody HuodongShenheEntity huodongShenhe, HttpServletRequest request){
        logger.debug("update方法:,,Controller:{},,huodongShenhe:{}",this.getClass().getName(),huodongShenhe.toString());

        String role = String.valueOf(request.getSession().getAttribute("role"));
//        if(StringUtil.isEmpty(role))
//            return R.error(511,"权限为空");
//        else if("学生".equals(role))
//            huodongShenhe.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
        //根据字段查询是否有相同数据
        Wrapper<HuodongShenheEntity> queryWrapper = new EntityWrapper<HuodongShenheEntity>()
            .notIn("id",huodongShenhe.getId())
            .andNew()
            .eq("huodong_id", huodongShenhe.getHuodongId())
            .eq("yonghu_id", huodongShenhe.getYonghuId())
            .eq("huodong_shenhe_yesno_types", huodongShenhe.getHuodongShenheYesnoTypes())
            .eq("huodong_text", huodongShenhe.getHuodongText())
            ;

        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        HuodongShenheEntity huodongShenheEntity = huodongShenheService.selectOne(queryWrapper);
        if(huodongShenheEntity==null){
            huodongShenheService.updateById(huodongShenhe);//根据id更新
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 删除
    */
    @RequestMapping("/delete")
    public R delete(@RequestBody Integer[] ids){
        logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
        huodongShenheService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
}

五、效果图

 

六、源码获取:

同系统在主页搜索资源可下载~

标签:Vue,return,SpringBoot,huodongShenhe,request,源码,role,id,view
From: https://blog.csdn.net/m0_48205251/article/details/142873642

相关文章