开源项目-投票管理系统

哈喽,大家好,今天主要给大家带来一个开源项目-投票管理系统

投票管理系统主要有首页,发起投票,管理投票,参与投票,查看投票等功能

首页

为用户提供了一键导航到各个功能模块的便捷途径。

新增投票

用户可以在此轻松创建新的投票活动,设置投票主题、选项等信息。

管理投票

管理员或投票发起人可以在此对已有的投票活动进行全面管理,包括编辑、删除、查看投票结果等操作。

参与投票

用户可以通过简单的操作,选择自己心仪的选项参与投票,表达自己的意见和看法。

查看投票

可以在此查看投票的详细结果,了解各个选项的得票情况,为后续决策提供参考。

代码示例

import java.util.ArrayList;
import java.util.List;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

import org.springframework.http.HttpRequest;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ModelAttribute;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.servlet.View;
import org.springframework.web.servlet.view.JstlView;

import com.wantao.bean.Page;
import com.wantao.bean.Vote;
import com.wantao.bean.VoteOption;
import com.wantao.bean.VoteResult;
import com.wantao.daoImpl.VoteDaoImpl;
import com.wantao.daoImpl.VoteOptionDaoImpl;
import com.wantao.util.ChartUtil;
import com.wantao.util.PageUtil;

@Controller
public class VoteHandler {
    @RequestMapping(value = "/addVote", method = RequestMethod.POST)
    public String addVote(int channel, String voteName, String[] voteOptions) {// 只要name属性相同,前后端自动绑定
       VoteDaoImpl voteDaoImpl = new VoteDaoImpl();
       VoteOptionDaoImpl voteOptionDaoImpl = new VoteOptionDaoImpl();
       Vote vote = new Vote();// 创建投票对象
       vote.setChannelId(channel);// 设置频道id
       vote.setVoteName(voteName);// 设置投票名称
       voteDaoImpl.addVote(vote);// 执行增加投票的方法
       int voteId = voteDaoImpl.findVoteByName(voteName).getVoteId();// 获取投票id
       for (String voteoption : voteOptions) {
          VoteOption voteOption = new VoteOption();// 创建投票选择对象
          voteOption.setVoteId(voteId);
          voteOption.setVoteOptionName(voteoption);
          voteOptionDaoImpl.addVoteOption(voteOption);
       }
       return "redirect:/index.jsp";
    }

    @RequestMapping(value = "/editorVote", method = RequestMethod.GET)
    public String editorVote(HttpSession session, @RequestParam(name = "currentPage") int currentPage) {
       VoteDaoImpl voteDaoImpl = new VoteDaoImpl();
       VoteOptionDaoImpl voteOptionDaoImpl = new VoteOptionDaoImpl();
       List voteIds=new ArrayList();
       Page page=null;
       int everyPageCount = 10;// 每页记录数
       int totalCount = voteDaoImpl.findAllVoteCount();// 总记录数
       if (currentPage ==1) {//第一页创建page对象
           page = PageUtil.createPage(currentPage, everyPageCount, totalCount);
          page.setBeginIndex(currentPage);
       }else {//非第一页直接获取page对象
       page =(Page) session.getAttribute("page");
       }
       page.setCurrentPage(currentPage);
       page.setHasNextPage(PageUtil.getHasNextPage(currentPage, page.getTotalPage()));
       page.setHasPrePage(PageUtil.getHasPrePage(currentPage));
       List<Vote> votes = voteDaoImpl.findAllVote(page);
       List<VoteResult> voteResults = new ArrayList<VoteResult>();
       for (Vote vote : votes) {
          VoteResult voteResult = new VoteResult();
          List<VoteOption> voteOptions = voteOptionDaoImpl.findVoteOptionByVoteId(vote.getVoteId());
          voteResult.setVote(vote);
          voteResult.setVoteOptions(voteOptions);
          voteResults.add(voteResult);
          voteIds.add(vote.getVoteId());
       }
       session.setAttribute("voteResults", voteResults);
       session.setAttribute("page", page);
       session.setAttribute("voteIds", voteIds);
       return "editorVote";
    }

    @RequestMapping(value = "/delete")
    public String deleteVote(@RequestParam(value = "currentPage") int currentPage, @RequestParam(value = "id") int id) {
       VoteDaoImpl voteDaoImpl = new VoteDaoImpl();
       VoteOptionDaoImpl voteOptionDaoImpl = new VoteOptionDaoImpl();
       voteOptionDaoImpl.deleteVoteOption(id);
       voteDaoImpl.deleteVote(id);
       return "redirect:editorVote?currentPage="+currentPage;
    }
}
以上就是系统的大致内容了,感兴趣的同学可以通过连接 下载​​​​​​​源码~

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Unity 两篇文章熟悉所有编辑器拓展关键类 (上)

本专栏基础资源来自唐老狮和siki学院&#xff0c;仅作学习交流使用&#xff0c;不作任何商业用途&#xff0c;吃水不忘打井人&#xff0c;谨遵教诲 编辑器扩展内容实在是太多太多了&#xff08;本篇就有五千字&#xff09; 所以分为两个篇章而且只用一些常用api举例&#xff0c…

rnn/lstm

tip&#xff1a;本人比较小白&#xff0c;看到july大佬的文章受益匪浅&#xff0c;现在其文章基础上加上自己的归纳、理解&#xff0c;以及gpt的答疑&#xff0c;如果有侵权会删。 july大佬文章来源&#xff1a;如何从RNN起步&#xff0c;一步一步通俗理解LSTM_rnn lstm-CSDN博…

【Docker大揭秘】

Docker 调试一天的血与泪的教训&#xff1a;设备条件&#xff1a;对应的build preparation相应的报错以及修改 作为记录 构建FASTLIO2启动docker获取镜像列出镜像运行containerdocker中实现宿主机与container中的文件互传 调试一天的血与泪的教训&#xff1a; 在DOCKER中跑通F…

APISQL企业版离线部署教程

针对政务、国企、医院、军工等内网物理隔离的客户&#xff0c;有时需要多次摆渡才能到达要安装软件的服务器。本教程将指导您使用Linux和Docker Compose编排服务&#xff0c;实现APISQL的离线部署。 准备 准备一台Linux(x86_64)服务器。 安装Docker Engine&#xff08;推荐版本…

音视频入门基础:AAC专题(11)——AudioSpecificConfig简介

音视频入门基础&#xff1a;AAC专题系列文章&#xff1a; 音视频入门基础&#xff1a;AAC专题&#xff08;1&#xff09;——AAC官方文档下载 音视频入门基础&#xff1a;AAC专题&#xff08;2&#xff09;——使用FFmpeg命令生成AAC裸流文件 音视频入门基础&#xff1a;AAC…

docker 可用镜像服务地址(2024.10.25亲测可用)

1.错误 Error response from daemon: Get “https://registry-1.docker.io/v2/” 原因&#xff1a;镜像服务器地址不可用。 2.可用地址 编辑daemon.json&#xff1a; vi /etc/docker/daemon.json内容修改如下&#xff1a; {"registry-mirrors": ["https://…

【AI应用落地实战】智能文档处理本地部署——可视化文档解析前端TextIn ParseX实践

湘江之畔&#xff0c;秋风送爽。前不久&#xff0c;2024长沙中国1024程序员节在长沙盛大举行。今年的程序员节主题为“智能应用新生态”&#xff0c;以科技为纽带&#xff0c;搭建起了一个共筑智能应用新生态的交流平台&#xff0c;众多技术大咖齐聚一堂&#xff0c;探讨智能应…

echarts实现 水库高程模拟图表

需求背景解决思路解决效果index.vue 需求背景 需要做一个水库高程模拟的图表&#xff0c;x轴是水平距离&#xff0c;y轴是高程&#xff0c;需要模拟改水库的形状 echarts 图表集链接 解决思路 配合ui切图&#xff0c;模拟水库形状 解决效果 index.vue <!--/*** author:…

Kubeadm搭建k8s

一、架构 节点名称规格IP地址安装组件master012C/4G&#xff0c;cpu核心数要求大于2192.168.88.76docker、kubeadm、kubelet、kubectl、flannelnode012C/2G192.168.88.20docker、kubeadm、kubelet、kubectl、flannelnode022C/2G192.168.88.21docker、kubeadm、kubelet、kubect…

transformers和bert实现微博情感分类模型提升

项目源码获取方式见文章末尾&#xff01; 600多个深度学习项目资料&#xff0c;快来加入社群一起学习吧。 《------往期经典推荐------》 项目名称 1.【LSTM模型实现光伏发电功率的预测】 2.【卫星图像道路检测DeepLabV3Plus模型】 3.【GAN模型实现二次元头像生成】 4.【CNN模…

【Apache Zookeeper】

一、简介 1、场景 如何让⼀个应⽤中多个独⽴的程序协同⼯作是⼀件⾮常困难的事情。开发这样的应⽤&#xff0c;很容易让很多开发⼈员陷⼊如何使多个程序协同⼯作的逻辑中&#xff0c;最后导致没有时间更好地思考和实现他们⾃⼰的应⽤程序逻辑&#xff1b;又或者开发⼈员对协同…

了解lwip

lwIP是一个小型的开源的TCP/IP协议栈&#xff08;精简版的TCP/IP协议&#xff09;&#xff0c;博客借用了其他博客的内容在此声明。 TCP/IP协议栈结构 应用层&#xff1a;HTTP,MQTT,NTP、FTP....... 传输层:TCP协议&#xff08;用于不可靠设备可靠传输&#xff09;&#xff…

基于Springboot+微信小程序的房产交易租赁服务平台设计与实现 (含源码数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 该系统…

《Linux运维总结:基于ARM64+X86_64架构CPU使用docker-compose一键离线部署redis 6.2.14容器版哨兵集群》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;《Linux运维篇&#xff1a;Linux系统运维指南》 一、部署背景 由于业务系统的特殊性&#xff0c;我们需要面向不通的客户安装我们的业务系统&…

【计算机网络 - 基础问题】每日 3 题(五十九)

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞…

Dolphins 简介——一种新颖的多模态语言模型

背景问题 现在的自动驾驶系统在处理复杂的多变的现实驾驶场景时&#xff0c;往往缺乏人类驾驶员的全面理解&#xff0c;及时学习和适应能力以及错误纠正能力&#xff0c;为了实现能够像人类一样理解和响应复杂现实世界场景的完全自主车辆(AV)一直是一个重要目标。Dolphins 是一…

LabVIEW汽车状态监测系统

LabVIEW汽车状态监测系统通过模拟车辆运行状态&#xff0c;有效地辅助工程师进行故障预测和维护计划优化&#xff0c;从而提高汽车的可靠性和安全性。 项目背景&#xff1a; 现代汽车工业面临着日益增长的安全要求和客户对于车辆性能的高期望。汽车状态监测系统旨在实时监控汽…

面试经典 150 题.P26. 删除有序数组中的重复项(003)

本题来自&#xff1a;力扣-面试经典 150 题 面试经典 150 题 - 学习计划 - 力扣&#xff08;LeetCode&#xff09;全球极客挚爱的技术成长平台https://leetcode.cn/studyplan/top-interview-150/ 题解&#xff1a; class Solution {public int removeDuplicates(int[] nums) …

FPGA时序分析和约束学习笔记(3、Timequest时序路径详解和优化)

FPGA时序分析和约束学习笔记&#xff08;3、Timequest时序路径详解和优化&#xff09; Timequest中Data Path分析 Data Arrival Path clock path&#xff1a;时钟信号到达源寄存器时钟端口的时间 data path&#xff1a;数据从源寄存器Q端口出发到达目标寄存器D端口的时间 D…

浮动+flex布局

一.浮动 1.介绍 2.效果 <style> .one{ width: 100px; height: 100px; background-color: red; float: left; } .two{ width: 200px; height: 200px; background-color: blue; float: right; } </style> </head> <body> <div class"one&quo…