基于Java+SpringMvc+vue+element实现高效学生社团平台管理

2年前 (2022) 程序员胖胖胖虎阿
331 0 0

🍅 作者简介:CSDN特邀作者✌、博客专家✌、java领域优质创作者💪

🍅关注公众号【java奥斯卡】  简历模板、学习资料、面试题库等都给你💪

🍅文末获取源码联系🍅

🍅新星计划·第三季【Java】赛道的报名入口!下一个新星就是你🍅

前言介绍:

        传统的社团管理方式是在线下实体进行的,由于社团构造的差异,用户需要到线下进行实际的体验,有很大的空间和时间限制。而随着社团类的不断普及,其性能、模块的透明化,越来越多的人群也开始出于各种各样的理由而热衷网上加入社团,传统的社团管理模式已经无法满足人的需求了。互联网的产生,带来了网络的再次高速发展,人们的生活得到了翻天覆地的变化。人们可以随时随地的享受互联网带来的方便快捷,在生活工作中的方方面面的需要都能在网络上实现,比如学习、加入等等。也就是说网络成了人们目前最直接、最方便、最轻松的接入口。

         在当今世界,互联网快速发展的现在,如何利用互联网创造更简单高效的生活,这是我们首要讨论的。需要社团信息管理相关网站,一方面使得管理员可以对社团管理的信息进行及时更新和信息化的管理,可以较为容易的获取各种社团信息的流通。另一方面用户可以利用互联网更直观的查看社团管理的相关信息。与传统的社团信息车方式相比,用户加入的方式更加轻松,系统的操作更加的准确,这是一种潜在趋势,或许可以有效加快社团管理的普及情况。

功能设计:

社团管理的主要开发目标如下:

(1)用户可以实时查看最新的社团信息,以及相关资讯;

(2)用户可以对比各大社团的信息,选择自己较为满意的社团;

(3)用户可以通过留言互相交流加入社团心得;

(4)管理员可以在后台方便管理前台网页的各种信息;

登录系统结构图,如图所示:

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

系统结构图,如图所示:

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

功能截图:

用户端:

用户登录:用户可以登录和注册、多角色登录、管理员只有一个。普通用户可以查看首页、个人中心、社团成员管理、活动报名管理、我的收藏管理等操作

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

用户首页:通过系统查看前台的社团信息、社团新闻、社团活动、留言反馈、我的个人信息

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团信息

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

 在社团页面中可以查看社团编号、社团名称、类型、图片、社团宗旨、创办日期、社团地址、联系电话、邮箱等可以申请加入、评论详细操作

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

申请加入社团、社团维护人员可以审核通过或不通过申请 基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团新闻

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团新闻详情页面也可以进行收藏和评论操作 

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

留言反馈:在留言反馈页面中用户可以进行留言,管理员和社团负责人会进行回复等详细操作

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

个人中心: 我的个人中心,在个人中心、我的收藏页面中可以查看户名、密码、姓名 、性别、头像、手机、邮箱、身份证等查看详情删除、修改等

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

普通用户后台:

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团人员后台:

主要功能有:首页、个人中心、社团信息管理、、社团新闻管理、用户咨询管理、社团活动管理、社团成员管理、社团经费管理、活动报名管理

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团管理员可以对社团活动申请或报名之类的进行审核

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

超级管理员后台:

超级管理员除了部分审核没有之外、其他的功能基本都有、能查看所有信息。首页、个人中心、用户管理、社团负责人管理、社团信息管理、社团分类管理、社团新闻管理、用户咨询管理、社团活动管理、社团成员管理、社团经费管理、活动报名管理、留言板管理、系统管理等

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

用户管理

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团管理

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

社团新闻管理

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

 社团经费

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

 留言板回复

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

系统轮播图

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

代码实现:




/**
 * 社团活动
 * 后端接口
 * @author 
 * @email 
 * @date 2022-11-26 08:47:15
 */
@RestController
@RequestMapping("/shetuanhuodong")
public class ShetuanhuodongController {
    @Autowired
    private ShetuanhuodongService shetuanhuodongService;
    


    /**
     * 后端列表
     */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params,ShetuanhuodongEntity shetuanhuodong, HttpServletRequest request){

		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("shetuanfuzeren")) {
			shetuanhuodong.setShetuanbianhao((String)request.getSession().getAttribute("username"));
		}
        EntityWrapper<ShetuanhuodongEntity> ew = new EntityWrapper<ShetuanhuodongEntity>();
		PageUtils page = shetuanhuodongService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shetuanhuodong), params), params));
        return R.ok().put("data", page);
    }
    
    /**
     * 前端列表
     */
	@IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params,ShetuanhuodongEntity shetuanhuodong, HttpServletRequest request){
        EntityWrapper<ShetuanhuodongEntity> ew = new EntityWrapper<ShetuanhuodongEntity>();
		PageUtils page = shetuanhuodongService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, shetuanhuodong), params), params));
        return R.ok().put("data", page);
    }

	/**
     * 列表
     */
    @RequestMapping("/lists")
    public R list( ShetuanhuodongEntity shetuanhuodong){
       	EntityWrapper<ShetuanhuodongEntity> ew = new EntityWrapper<ShetuanhuodongEntity>();
      	ew.allEq(MPUtil.allEQMapPre( shetuanhuodong, "shetuanhuodong")); 
        return R.ok().put("data", shetuanhuodongService.selectListView(ew));
    }

	 /**
     * 查询
     */
    @RequestMapping("/query")
    public R query(ShetuanhuodongEntity shetuanhuodong){
        EntityWrapper< ShetuanhuodongEntity> ew = new EntityWrapper< ShetuanhuodongEntity>();
 		ew.allEq(MPUtil.allEQMapPre( shetuanhuodong, "shetuanhuodong")); 
		ShetuanhuodongView shetuanhuodongView =  shetuanhuodongService.selectView(ew);
		return R.ok("查询社团活动成功").put("data", shetuanhuodongView);
    }
	
    /**
     * 后端详情
     */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") String id){
        ShetuanhuodongEntity shetuanhuodong = shetuanhuodongService.selectById(id);
        return R.ok().put("data", shetuanhuodong);
    }

    /**
     * 前端详情
     */
	@IgnoreAuth
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") String id){
        ShetuanhuodongEntity shetuanhuodong = shetuanhuodongService.selectById(id);
        return R.ok().put("data", shetuanhuodong);
    }
    



    /**
     * 后端保存
     */
    @RequestMapping("/save")
    public R save(@RequestBody ShetuanhuodongEntity shetuanhuodong, HttpServletRequest request){
    	shetuanhuodong.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(shetuanhuodong);

        shetuanhuodongService.insert(shetuanhuodong);
        return R.ok();
    }
    
    /**
     * 前端保存
     */
    @RequestMapping("/add")
    public R add(@RequestBody ShetuanhuodongEntity shetuanhuodong, HttpServletRequest request){
    	shetuanhuodong.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
    	//ValidatorUtils.validateEntity(shetuanhuodong);

        shetuanhuodongService.insert(shetuanhuodong);
        return R.ok();
    }

    /**
     * 修改
     */
    @RequestMapping("/update")
    public R update(@RequestBody ShetuanhuodongEntity shetuanhuodong, HttpServletRequest request){
        //ValidatorUtils.validateEntity(shetuanhuodong);
        shetuanhuodongService.updateById(shetuanhuodong);//全部更新
        return R.ok();
    }
    

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public R delete(@RequestBody Long[] ids){
        shetuanhuodongService.deleteBatchIds(Arrays.asList(ids));
        return R.ok();
    }
    
    /**
     * 提醒接口
     */
	@RequestMapping("/remind/{columnName}/{type}")
	public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request, 
						 @PathVariable("type") String type,@RequestParam Map<String, Object> map) {
		map.put("column", columnName);
		map.put("type", type);
		
		if(type.equals("2")) {
			SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
			Calendar c = Calendar.getInstance();
			Date remindStartDate = null;
			Date remindEndDate = null;
			if(map.get("remindstart")!=null) {
				Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
				c.setTime(new Date()); 
				c.add(Calendar.DAY_OF_MONTH,remindStart);
				remindStartDate = c.getTime();
				map.put("remindstart", sdf.format(remindStartDate));
			}
			if(map.get("remindend")!=null) {
				Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
				c.setTime(new Date());
				c.add(Calendar.DAY_OF_MONTH,remindEnd);
				remindEndDate = c.getTime();
				map.put("remindend", sdf.format(remindEndDate));
			}
		}
		
		Wrapper<ShetuanhuodongEntity> wrapper = new EntityWrapper<ShetuanhuodongEntity>();
		if(map.get("remindstart")!=null) {
			wrapper.ge(columnName, map.get("remindstart"));
		}
		if(map.get("remindend")!=null) {
			wrapper.le(columnName, map.get("remindend"));
		}

		String tableName = request.getSession().getAttribute("tableName").toString();
		if(tableName.equals("shetuanfuzeren")) {
			wrapper.eq("shetuanbianhao", (String)request.getSession().getAttribute("username"));
		}

		int count = shetuanhuodongService.selectCount(wrapper);
		return R.ok().put("count", count);
	}
	


}

数据设计:

     数据库的功能就是对系统中所有的数据进行存储和管理。所有的数据可以在数据库中产时间的进行存储,方便用户的使用。而且所有的数据库中的数据也应该具有一定的共享性,任何的系统可以对一些数据进行使用,同时还应该保持一定的独立性,每一个数据库中的数据都有很强的安全性,可以被很好的存放到数据库,没有进行身份的验证是不能对这些数据进行查看和使用的。数据库的设计需要明确每一个实体之间的联系,系统的E-R图如下图所示::

管理员实体主要存储管理信息包账号、密码、验证码、角色属性。管理员信息属性图如图4-5所示。

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

图 管理员信息实体属性图

用户信息主要包括用户名、密码、姓名 、性别、头像、手机、邮箱、身份证等属性,用户信息属性图如图所示

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

图用户信息实体属性图

社团负责人管理实体属性主要包括社团编号、密码、姓名、社团名称、性别、头像、联系电、话邮箱、身份证等属性。社团负责人管理实体属性图如图所示。

基于Java+SpringMvc+vue+element实现高效学生社团平台管理

图社团负责人管理实体属性图

论文参考:

摘  要

Abstract

第1章  前  言

1.1  研究背景

1.2  研究现状

1.3  系统开发目标

第2章  技术与原理

2.1  JSP介绍

2.2  JAVA技术

2.3  MySQL数据库

2.4  B/S结构

2.5  SSM介绍

第3章  需求分析

3.1  需求分析

3.2  系统可行性分析

3.3  项目设计目标与原则

3.4  系统流程分析

第4章  架构设计

4.1  系统体系结构

4.2  数据库实体设计

4.3  数据库表设计

第5章  系统实现

5.1  管理员功能模块

5.2  社团负责人功能模块

5.3 用户后台功能模块

第6章  系统测试

6.1  测试目的

6.2  测试方法

6.3  功能测试

6.4  测试结论

第7章 结  论

参考文献

致  谢  

获取源码:

大家点赞、收藏、关注、评论啦 、查看👇🏻👇🏻👇🏻微信公众号获取联系方式👇🏻👇🏻👇🏻

打卡 文章 更新 226/  365天

 精彩专栏推荐订阅:下方专栏👇🏻👇🏻👇🏻👇🏻

Java项目精品实战案例《100套》

web前端期末大作业网页实战《100套》

相关文章

暂无评论

暂无评论...