Java项目:ssm赛事打分系统

news2024/9/24 13:24:01

作者主页:源码空间站2022

 简介:Java领域优质创作者、Java项目、学习资料、技术互助

文末获取源码

项目介绍

赛事评分系统,SSM框架。该项目分管理员、裁判、选手三个用户角色。

管理员主要功能:
首页、选手管理、裁判管理、赛事管理
裁判主要功能:
首页、评分;
选手主要功能:
首页、报名赛事、查看成绩;

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.是否Maven项目: 是;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目 
6.数据库:MySql 5.7版本;
7.lombok插件 注:必须安装,否则会报错

技术栈

1. 后端:Spring SpringMVC MyBatis
2. 前端:Layui

使用说明

1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 将项目中database.properties配置文件中的数据库配置改为自己的配置;
3. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,配置tomcat,然后运行;
4. 运行项目,输入localhost:8080/xxx 登录

运行截图

相关代码 

JudgeController

package com.thunder.controller;

import com.alibaba.fastjson.JSONObject;
import com.thunder.pojo.Judge;
import com.thunder.pojo.Mark;
import com.thunder.pojo.Match;
import com.thunder.pojo.User;
import com.thunder.service.impl.JudgeServiceImpl;
import com.thunder.service.impl.LoginServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.Date;
import java.util.Map;


@Controller
@RequestMapping("/judge")
public class JudgeController {

    @Autowired
    JudgeServiceImpl judgeService;
    @Autowired
    LoginServiceImpl loginService;

    /**
     * 跳转 裁判页面
     */
    @RequestMapping("/toJudgePage")
    public String toJudgePage() {
        return "/pages/judge";
    }

    /**
     * 跳转 评分
     */
    @RequestMapping("/toMark")
    public String toMark() {
        return "/pages/judgeMarkPlayer";
    }

    /**
     * 获取所有裁判
     */
    @RequestMapping(value = "/getAllJudge", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String getAllJudge() {
        //阿里巴巴的json数据格式交互
        JSONObject object = new JSONObject();
        object.put("code", 200);//原来是 code : 0
        object.put("msg", "");
        object.put("data", judgeService.getAllJudge());
        object.put("count", judgeService.getAllJudge().size());

        System.out.println("数据库数据:" + judgeService.getAllJudge().toString());
        return object.toJSONString();
    }

    /**
     * 根异步请求 删除裁判
     */
    @RequestMapping("/deleteJudgeById")
    @ResponseBody
    public String deleteJudgeById(@RequestParam Map map) {
        String currentJudge = (String) map.get("index");
        int result = judgeService.deleteJudgeById(currentJudge);
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }

    //添加 裁判
    @RequestMapping("/addJudgeAjax")
    @ResponseBody
    public String addJudgeAjax(@RequestParam Map map) {
        System.out.println(map);

        String jid = (String) map.get("jid");
        String jname = (String) map.get("jname");
        String jage = (String) map.get("jage");
        String jsex = (String) map.get("jsex");
        System.out.println(jid + " " + jname + " " + jage + " " + jsex);
       
        //判断裁判、选手 写入 user表
        if (jid.contains("P")) {
            System.out.println("注册选手");
            int registerPlayer = loginService.addUser(new User(jid, password));
            if (registerPlayer > 0) {
                System.out.println("注册选手成功!");
            }
        } else if (jid.contains("J")) {
            System.out.println("注册裁判");
            int registerPlayer = loginService.addUser(new User(jid, password));
            if (registerPlayer > 0) {
                System.out.println("注册裁判成功!");
            }
        } else if (jid.equals("admin")) {
            System.out.println("管理员");
        } else {

        }
        //添加 裁判
        int result = judgeService.addJudgeAjax(new Judge(jid, jname, jage, jsex));
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }

    //裁判打分
    @RequestMapping("/mark")
    @ResponseBody
    public String mark(@RequestParam Map map) {
        System.out.println("进入 后台 ==== 打分");
        String pid = (String) map.get("pid");
        String item = (String) map.get("mid");
        String jid = (String) map.get("jid");
        String score = (String) map.get("score");
        System.out.println("分数是:" + score + item + jid + pid);
        int result = judgeService.mark(new Mark(score, item, jid, pid));
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }


}

LoginController

package com.thunder.controller;

import com.thunder.pojo.User;
import com.thunder.service.impl.JudgeServiceImpl;
import com.thunder.service.impl.LoginServiceImpl;
import com.thunder.service.impl.PlayServiceImpl;
import com.thunder.util.CurrentUser;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpSession;
import java.util.Map;

@Controller
public class LoginController {

    @Autowired
    LoginServiceImpl loginService;
    @Autowired
    JudgeServiceImpl judgeService;
    @Autowired
    PlayServiceImpl playService;

    /**
     * 登录验证
     */
    @RequestMapping(value = "/login", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String Login(@RequestParam Map user, HttpSession session) {
        String account = (String) user.get("account");
        String password = (String) user.get("password");
        if (account.contains("P")) {
            System.out.println("选手登录");
            if (LoginRoute(account, password, session).equals("1")) {
                return "选手登录";
            } else {
                return "error";
            }
        } else if (account.contains("J")) {
            System.out.println("裁判登录");
            if (LoginRoute(account, password, session).equals("1")) {
                return "裁判登录";
            } else {
                return "error";
            }
        } else if (account.equals("admin")) {
            System.out.println("管理员登录");
            if (LoginRoute(account, password, session).equals("1")) {
                return "admin";
            } else {
                return "error";
            }
        } else {
            return "error";
        }
    }

    //判断用户
    public String LoginRoute(String account, String password, HttpSession session) {
        User loginUser = loginService.getUser(account);
        if (loginUser != null) {
            if (!loginUser.getPwd().equals(password)) {
                return "error";
            } else {
                session.setAttribute(CurrentUser.CURRENT_USER, loginUser);
                System.out.println("session放入" + loginUser.getAccount());
                return "1";
            }
        } else {
            return "error";
        }
    }

    /**
     * 注册用户
     */
    @RequestMapping("/register")
    @ResponseBody
    public String Register(@RequestParam Map user) {
        String loginuser = (String) user.get("user");
        String password = (String) user.get("pwd");

        System.out.println(user.get("user"));
        System.out.println(user.get("pwd"));



        User newUser = new User((String) user.get("user"), (String) user.get("pwd"));
        int result = loginService.addUser(newUser);
        //添加成功 返回 大于0
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }

    /**
     * 判断 注册用户 是否存在数据库中 ajax
     */
    @RequestMapping("/registerAccount")
    @ResponseBody
    public String registerAccount(@RequestParam Map user) {
        System.out.println("当前新增用户:" + user.get("user"));
        String newUser = (String) user.get("user");
        User userNewUser = loginService.getUser(newUser);
        if (userNewUser != null) {
            return "error";
        } else {
            return "1";
        }
    }

    /**
     * 去往主页面
     */
    @RequestMapping("/toMain")
    public String toMain() {
        return "pages/main";
    }

    /**
     * 退出登录
     */
    @RequestMapping("/exitLogin")
    public String exitLogin(HttpSession session) {
        session.removeAttribute(CurrentUser.CURRENT_USER);
        //session.invalidate();
        if (session == null) {
            System.out.println("当前用户:" + session.getAttribute(CurrentUser.CURRENT_USER));
            return "redirect:/login.jsp";
        } else {
            System.out.println("当前用户:" + session.getAttribute(CurrentUser.CURRENT_USER));
            return "redirect:/login.jsp";
        }

    }


}

MatchController

package com.thunder.controller;

import cn.hutool.core.date.DateTime;
import cn.hutool.core.date.DateUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.thunder.pojo.Match;
import com.thunder.pojo.SignUp;
import com.thunder.service.impl.MatchServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.List;
import java.util.Map;

@Controller
@RequestMapping("/match")
public class MatchController {

    @Autowired
    MatchServiceImpl matchService;

    /**
     * 跳转到 赛事界面
     */
    @RequestMapping("/toMatchPage")
    public String toMatchPage() {
        return "/pages/match";
    }

    /**
     * 获取所有赛事 admin页面展示
     */
    @RequestMapping(value = "/getAllMatch", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String getAllMatch() {
        //阿里巴巴的json数据格式交互
        JSONObject object = new JSONObject();
        object.put("code", 200);//原来是 code : 0
        object.put("msg", "");
        object.put("data", matchService.getAllMatch());
        object.put("count", matchService.getAllMatch().size());

        System.out.println("数据库数据:" + matchService.getAllMatch().toString());
        return object.toJSONString();
    }

    /**
     * 获取赛事 ajax 下拉列表
     */
    @RequestMapping(value = "/getAllMatchAjax", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String getAllMatchAjax() {
        List<Match> allMatch = matchService.getAllMatch();
        JSONArray array = JSONArray.parseArray(JSON.toJSONString(allMatch));
        System.out.println(array.toJSONString());

        return array.toJSONString();
    }

    /**
     * 删除操作 异步请求
     */
    @RequestMapping("/deleteMatchById")
    @ResponseBody
    public String deleteMatchById(@RequestParam Map map) {
        int currentMatchId = Integer.parseInt((String) map.get("index"));
        int result = matchService.deleteMatchById(currentMatchId);
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }

    /**
     * 添加赛事
     */
    @RequestMapping(value = "/addMatchAjax", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String addMatchAjax(@RequestParam Map map) {
        //System.out.println(map);

        String mid = (String) map.get("mid");
        String mname = (String) map.get("mname");
        String mtime = (String) map.get("mtime");

        DateTime parseDate = DateUtil.parse(mtime, "yyyy-MM-dd");
        java.sql.Date mtimeDate = new java.sql.Date(parseDate.getTime());
        System.out.println("类型" + mtimeDate.getClass().getName());
        System.out.println("mid=" + mid + "mname=" + mname + "mtime=" + mtimeDate);
        int result = matchService.addMatchAjax(new Match(mid, mname, mtimeDate));
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }


    }

    //选手报名赛事
    @RequestMapping(value = "/signInMatch", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String signInMatch(@RequestParam Map map) {
        System.out.println(map);
        String pid = (String) map.get("pid");
        String saishi = (String) map.get("saishi");
        String properties = (String) map.get("properties");
        System.out.println("pid " + pid + " saishi:" + saishi + "性质:" + properties);
        int result = matchService.signInMatch(new SignUp(pid, saishi, properties));
        if (result > 0) {
            return "1";
        } else {
            return "error";
        }
    }

    /***
     *查看已报名
     */
    @RequestMapping(value = "/alreadySignIn", produces = "application/json;charset=UTF-8")
    @ResponseBody
    public String alreadySignIn(@RequestParam Map map) {
        JSONObject object = new JSONObject();

        String pid = (String) map.get("pid");
        System.out.println("选手:" + pid + "选择的赛事");
        List<SignUp> signUpList = matchService.alreadySignIn(pid);
        object.put("code", 200);//原来是 code : 0
        object.put("msg", "");
        object.put("data", signUpList);
        object.put("count", signUpList.size());

        System.out.println("已报名:" + signUpList);
        return object.toJSONString();
    }
}

如果也想学习本系统,下面领取。关注并回复:034ssm 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/56946.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【2022世界杯开源项目实战】使用docker部署world-cup-2022-cli-dashboard数据看板工具

【2022世界杯开源项目实战】使用docker部署world-cup-2022-cli-dashboard数据看板工具一、world-cup-2022-cli-dashboard介绍1.工具介绍2.数据看板的内容二、检查本地docker环境1.检查docker版本2.检查docker状态三、构建world-cup-2022-cli-dashboard的镜像1.下载world-cup-20…

如何用蓝牙实现无线定位(四)--远程定位显示

1. 待救援定位设备 按照下面的针脚使用杜邦线将待救援定位设备的主蓝牙、从蓝牙连接到主控板上&#xff0c;和本地显示时的连接针脚是一样的&#xff0c;但是由于不需要连接OLED&#xff0c;因此不需要堆叠Bigfish。 参考视频 烧录程序如下&#xff08;human.ino&#xff09;&a…

善网ESG周报(第三期)

ESG报告&#xff1a; 陆金所控股发布2021年ESG报告 以可持续商业模式创造社会价值 从11月28日发布的报告来看&#xff0c;其公司2021年累计帮助超310万小微企业主并开展170场环保公益活动和超610场金融科普活动。 金融界联合济安金信发布首份《京津冀ESG绿色标杆企业报告》&a…

Keras深度学习高级(四)

本篇涉及的内容 如何将模型的结构由层升级成图如何使用 Keras 的回调函数在训练过程中监控模型&#xff0c;并根据模型状态采取行动使用TensorBoard将模型可视化什么是批标准化、深度可分离卷积和残差连接为什么应该使用超参数优化和模型集成 第一部分 Keras的函数式API 一、…

Nexus私服 (一)

(一) Nexus-OSS私服介绍 平时用maven构建项目&#xff0c;pom会默认去maven仓库下载包&#xff0c;网速都比较慢。此时可以选择国内的镜像&#xff08;ex:阿里云仓库&#xff09;如果想要自己管理项目的包&#xff0c;亦或者你的开源项目有多个人维护的时候&#xff0c;就需要考…

Allegro如何添加泪滴操作指导

Allegro如何添加泪滴操作指导 Allegro支持添加泪滴操作,保证焊接的可靠性,还可以调整泪滴的大小和形状,类似下图 具体操作如下 以给下图的pin和孔加泪滴为例 首先设置参数,route-Gloss-Parameters 点击Fillet and Taper Trace前面的方框 勾选下方的参数,Max size的值…

自己编写程序publish出kitti数据集,可视化kitti数据集

目的:不使用kitti2bag,因为kitti2bag的格式都是固定的,如果将来自己要添加什么东西,这个就会变得非常麻烦,自己编写程序就会右很多的变化。 开始之前仍然要下载kitti数据集,下载方式参考Ubuntu1804里进行KITTI数据集可视化操作_FYY2LHH的博客-CSDN博客 1、先执行roscor…

一款.Net7前后端分离、跨平台的通用权限管理框架

今天给大家推荐一个开源项目&#xff0c;基于.NetCore开发的、多租户的、前后端分离的企业开发框架。 项目简介 这是一个前后端分离、跨平台的、基于RBAC的通用框架&#xff1b;支持多租户、任务调度、缓存、国际化&#xff0c;前端支持Vue2/3&#xff0c;支持分表分库。 框…

【图像分类损失】SimLoss:一个适合于年龄估计的分类损失

Roses are red, violets are blue, both are somehow similar, but the classifier has no clue. 论文题目&#xff1a;《SimLoss: Class Similarities in Cross Entropy》&#xff08;2020年&#xff09; 论文地址&#xff1a;https://arxiv.org/pdf/2003.03182v1.pdf 1.背景…

Hbuilder打包成APP流程,以及遇到的坑

1.打包项目 期间遇到的坑&#xff0c;提前说下&#xff0c;避免重复工作。 【因为很多网友说自己打包的APP是白屏&#xff0c;这是需要实名认证才能使用的工具&#xff0c;灰灰产还是用其他的工具吧】 我打包的安卓APP给大家欣赏一下&#xff1a; https://wwttl.lanzout.co…

Spring MVC使用SessionLocaleResolver实现用户自定义切换语言实例

在许多成熟的商业软件系统中可以让用户自由切换语言&#xff0c;而不是修改浏览器的语言设置。一旦用户选择了自己需要使用的语言环境&#xff0c;整个系统的语言环境将一直是这种语言环境。 Spring MVC 也可以允许用户自行选择程序语言。本章通过 Web 应用 springMVCDemo09 演…

Linux安装使用Minio

目录简介安装方式1(推荐)安装方式2使用简介 需要一个靠谱的文件管理系统&#xff0c;所以想到了minio。在此记录过程。使用树莓派搭建。Linux下载不同的包即可。 官网地址&#xff1a;https://www.minio.org.cn/ 官方下载地址&#xff1a;https://dl.min.io/server/minio/rele…

FFmpeg二次开发

本文主要讲解 FFmpeg 的二次开发&#xff0c;ffmpeg.exe 的命令行功能特别强大&#xff0c;很多需求都能直接用命令行实现&#xff0c;但是总有一些需求用 命令行实现不太好做。 而你实现那些特殊需求&#xff0c;通常需要把 ffmpeg.exe 里面的某部分代码抄过来&#xff0c;本…

Android databinding之RecycleView使用与讲解(二)

一 、介绍 通过上一篇databinding接入&#xff0c;我们已大概了解到databinding接入的流程和数据的简单绑定。 如果你刚看这边&#xff0c;并不了解databinding的使用&#xff0c;可以查看&#xff1a;Android databinding的接入使用与详解(一) Activity和fragment的数据绑定…

Pr:导出设置之字幕

如果序列中包含字幕轨道&#xff0c;则导出设置中的字幕 CAPTIONS模块将提供用于处理字幕信息的选项。如果源序列不包含任何字幕轨道&#xff0c;此模块将被禁用。导出选项Export Options选择导出活动字幕轨道的方式。--无None若选择此项&#xff0c;则不以任何形式导出字幕。-…

flink状态与容错-1.13

1. 版本说明 本文档内容基于 flink-1.13.x&#xff0c;其他版本的整理&#xff0c;请查看本人博客的 flink 专栏其他文章。 2. Checkpoint 2.1. 概述 Checkpoint 使 Flink 的状态具有良好的容错性&#xff0c;通过 checkpoint 机制&#xff0c;Flink 可以对作业的状态和计算…

【Java实战】这样写代码与Bug说拜拜

目录 一、前言 二、OOP 规约 1.【强制】避免通过一个类的对象引用访问此类的静态变量或静态方法&#xff0c;无谓增加编译器解析成本&#xff0c;直接用类名来访问即可。 2.【强制】所有的覆写方法&#xff0c;必须加 Override 注解。 3.【强制】相同参数类型&#xff0c;相…

手把手教你成为荣耀开发者:账户结算操作指南

荣耀开发者服务平台是荣耀面向开发者的统一生态入口&#xff0c;通过聚合周边内外部系统&#xff0c;分全球多站点部署&#xff0c;为全球开发者提供业务全生命周期的商业支撑服务&#xff0c;拥有应用分发、智慧服务、开放能力、HONOR Connect等众多业务等您来合作。 账户结算…

408 考研《操作系统》第一章第二节:操作系统的发展与分类和操作系统的运行机制与体系结构

文章目录教程1. 操作系统的发展与分类1.1 手工操作阶段1.2 批处理阶段1.2.1 单道批处理系统1.2.2 多道批处理系统1.3 分时操作系统1.4 实时操作系统1.5 其他几种操作系统1.6 总结教程 操作系统的发展与分类https://www.bilibili.com/video/BV1YE411D7nH/?p4&share_source…

本周推荐 | mysql中业务系统可借鉴的设计

推荐语&#xff1a;学习优秀的开源系统来优化我们业务的架构设计&#xff0c;这是我们作为业务开发的必修课&#xff0c;这篇文章从经典的mysql系统原理引申到业务系统设计思考&#xff0c;让人耳目一新&#xff0c;值得我们学习。——大淘宝技术工程师 默达如果一个系统能存活…