主介绍:?在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计?
项目名称
SSM框架基于JavaWeb在线投票系统的设计与实现源码
视频效果
SSM框架基于JavaWeb在线投票系统的设计与实现源码
SSM框架基于JavaWeb在线投票系统的设计与实现源码
系统说明
根据系统分析,将在线投票管理系统分为前台功能模块和后台功能模块。其中系统前台功能实现用户注册、用户登录、浏览、投票、投票中心和投票历史等功能。系统前台功能如图5-2所示:
?编辑
图5-2 系统前台功能模块结构图
用户注册:用户填写用户名、密码和性别,点击注册按钮进行注册。
用户登录:用户填写已经注册的用户名和密码,点击登录按钮进行登录。
浏览:用户可以浏览在线投票管理系统中公共开放内容。
投票:用户选择自己需要的投票,针对主题,勾选选项,进行投票操作。投票方式支持单选只能投一次、单选一天只能投一次、多选只能投一次、多选一天只能投一次等四种方式。
投票中心:在线投票管理系统展示所有投票主题供用户选择。
投票历史:存储用户已经投票的历史内容,用户登陆后方可查看。
系统后台功能实现以下功能,投票信息管理、详细投票查看、用户信息管理、投票信息统计和管理员登录等功能。系统后台功能如图5-3所示:
?编辑
图5-3 系统后台功能模块结构图
投票信息管理:管理员进行投票信息管理,可以管理投票主题和投票选项。针对投票主题,可以添加投票主题(需要填写主题名称、主题类型、开始时间、结束时间和主题简介)、查看主题、修改主题和删除主题;针对投票选项管理,可以添加选项(需要填写选项名称和选择所属主题)、查看选项、修改选项和删除选项。
详细投票查看:管理员查看投票的详细信息,以列表形式显示,每条投票详细信息包括:投票ID、用户名、投票主题、投票选项、总投票数和投票时间等信息。
用户信息管理:管理员进行用户信息管理,可以添加用户(需要填写用户名、密码、性别和状态)、查看用户信息、修改用户信息和删除用户。
投票信息统计:管理员进行投票信息统计,默认显示所有的投票主题统计,输入搜索主题名称后显示单个主题的投票统计。
管理员登录:管理员输入用户名、密码和验证码,点击登录按钮,进行登录操作。
环境需要
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.数据库:MySql 5.7版本;
6.是否Maven项目:否;
技术栈
1. 后端:Spring+SpringMVC+Mybatis
2. 前端:JSP+CSS+JavaScript+jQuery
使用说明
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中springmvc-servlet.xml配置文件中的数据库配置改为自己的配置;
4. 运行项目,在浏览器中输入http://localhost:8080/ 登录
运行截图
?编辑
?编辑
?编辑
?编辑
?编辑
?编辑
?编辑
?编辑
?编辑
?编辑
用户管理控制层:
package com.houserss.controller;
import javax.servlet.http.HttpSession;
import org.apache.commons.lang3.StringUtils;
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.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import com.houserss.common.Const;
import com.houserss.common.Const.Role;
import com.houserss.common.ServerResponse;
import com.houserss.pojo.User;
import com.houserss.service.IUserService;
import com.houserss.service.impl.UserServiceImpl;
import com.houserss.util.MD5Util;
import com.houserss.util.TimeUtils;
import com.houserss.vo.DeleteHouseVo;
import com.houserss.vo.PageInfoVo;
/**
* Created by admin
*/
@Controller
@RequestMapping("/user/")
public class UserController {
@Autowired
private IUserService iUserService;
/**
* 用户登录
* @param username
* @param password
* @param session
* @return
*/
@RequestMapping(value="login.do",method=RequestMethod.POST)
@ResponseBody
public ServerResponse<User> login(User user,String uvcode, HttpSession session){
String code=(String)session.getAttribute("validationCode");
if(StringUtils.isNotBlank(code)) {
if(!code.equalsIgnoreCase(uvcode)) {
return ServerResponse.createByErrorMessage("验证码不正确");
}
}
ServerResponse<User> response=iUserService.login(user.getUsername(),user.getPassword());
if(response.isSuccess()){
session.setAttribute(Const.CURRENT_USER,response.getData());
}
return response;
}
}
管理员管理控制层:
package com.sxl.controller.admin;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import com.sxl.controller.MyController;
@Controller("adminController")
@RequestMapping(value="/admin")
public class AdminController extends MyController {
@RequestMapping(value="/index")
public String frame(Model model, HttpServletRequest request)throws Exception {
return "/admin/index";
}
@RequestMapping(value="/main")
public String main(Model model, HttpServletRequest request)throws Exception {
return "/admin/main";
}
@RequestMapping(value="/tj1")
public String tj1(Model model, HttpServletRequest request)throws Exception {
String sql="select DATE_FORMAT(insertDate,'%Y-%m-%d') dates,sum(allPrice) price from t_order order by DATE_FORMAT(insertDate,'%Y-%m-%d') desc";
List<Map> list=db.queryForList(sql);
model.addAttribute("list", list);
System.out.println(list);
return "/admin/tj/tj1";
}
@RequestMapping(value="/password")
public String password(Model model, HttpServletRequest request)throws Exception {
return "/admin/password";
}
@RequestMapping(value="/changePassword")
public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
Map admin=getAdmin(request);
if(oldPassword.equals(admin.get("password").toString())){
String sql="update t_admin set password=? where id=?";
db.update(sql, new Object[]{newPassword,admin.get("id")});
return renderData(true,"1",null);
}else{
return renderData(false,"1",null);
}
}
}
修改密码业务逻辑:
package com.sxl.controller.admin;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.http.ResponseEntity;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import com.sxl.controller.MyController;
@Controller("userController")
@RequestMapping(value="/user")
public class UserController extends MyController {
@RequestMapping(value="/index")
public String frame(Model model, HttpServletRequest request)throws Exception {
return "/user/index";
}
@RequestMapping(value="/main")
public String main(Model model, HttpServletRequest request)throws Exception {
return "/user/main";
}
@RequestMapping(value="/password")
public String password(Model model, HttpServletRequest request)throws Exception {
return "/user/password";
}
@RequestMapping(value="/changePassword")
public ResponseEntity<String> loginSave(Model model,HttpServletRequest request,String oldPassword,String newPassword) throws Exception {
Map user=getUser(request);
if(oldPassword.equals(user.get("password").toString())){
String sql="update t_user set password=? where id=?";
db.update(sql, new Object[]{newPassword,user.get("id")});
return renderData(true,"1",null);
}else{
return renderData(false,"1",null);
}
}
@RequestMapping(value="/mine")
public String mine(Model model, HttpServletRequest request)throws Exception {
Map user=getUser(request);Map map=db.queryForMap("select * from t_user where id=?",new Object[]{user.get("id")});model.addAttribute("map", map); return "/user/mine";
}
@RequestMapping(value="/mineSave")
public ResponseEntity<String> mineSave(Model model,HttpServletRequest request,Long id
,String username,String password,String name,String gh,String mobile) throws Exception{
int result=0;
String sql="update t_user set name=?,gh=?,mobile=? where id=?";
result=db.update(sql, new Object[]{name,gh,mobile,id});
if(result==1){
return renderData(true,"操作成功",null);
}else{
return renderData(false,"操作失败",null);
}
}
}
通用管理模块:
package com.sxl.controller;
import java.nio.charset.Charset;
import java.util.Locale;
import java.util.ResourceBundle;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.lang.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import com.sxl.util.JacksonJsonUtil;
import com.sxl.util.StringUtil;
import com.sxl.util.SystemProperties;
public class BaseController {
public static final Long EXPIRES_IN=1000 * 3600 * 24 * 1L;// 1天
@Autowired
private SystemProperties systemProperties;
/**
* 获得配置文件内容
*/
public String getConfig(String key) {
return systemProperties.getProperties(key);
}
/**
* 返回服务器地址 like http://192.168.1.1:8441/UUBean/
*/
public String getHostUrl(HttpServletRequest request) {
String hostName=request.getServerName();
Integer hostPort=request.getServerPort();
String path=request.getContextPath();
if (hostPort==80) {
return "http://" + hostName + path + "/";
} else {
return "http://" + hostName + ":" + hostPort + path + "/";
}
}
/***
* 获取当前的website路径 String
*/
public static String getWebSite(HttpServletRequest request) {
String returnUrl=request.getScheme() + "://"
+ request.getServerName();
if (request.getServerPort() !=80) {
returnUrl +=":" + request.getServerPort();
}
returnUrl +=request.getContextPath();
return returnUrl;
}
/**
* 初始化HTTP头.
*
* @return HttpHeaders
*/
public HttpHeaders initHttpHeaders() {
HttpHeaders headers=new HttpHeaders();
MediaType mediaType=new MediaType("text", "html",
Charset.forName("utf-8"));
headers.setContentType(mediaType);
return headers;
}
/**
* 返回 信息数据
*
* @param status
* @param msg
* @return
*/
public ResponseEntity<String> renderMsg(Boolean status, String msg) {
if (StringUtils.isEmpty(msg)) {
msg="";
}
String str="{\"status\":\"" + status + "\",\"msg\":\"" + msg + "\"}";
ResponseEntity<String> responseEntity=new ResponseEntity<String>(str,
initHttpHeaders(), HttpStatus.OK);
return responseEntity;
}
/**
* 返回obj数据
*
* @param status
* @param msg
* @param obj
* @return
*/
public ResponseEntity<String> renderData(Boolean status, String msg,
Object obj) {
if (StringUtils.isEmpty(msg)) {
msg="";
}
StringBuffer sb=new StringBuffer();
sb.append("{");
sb.append("\"status\":\"" + status + "\",\"msg\":\"" + msg + "\",");
sb.append("\"data\":" + JacksonJsonUtil.toJson(obj) + "");
sb.append("}");
ResponseEntity<String> responseEntity=new ResponseEntity<String>(
sb.toString(), initHttpHeaders(), HttpStatus.OK);
return responseEntity;
}
/***
* 获取IP(如果是多级代理,则得到的是一串IP值)
*/
public static String getIpAddr(HttpServletRequest request) {
String ip=request.getHeader("x-forwarded-for");
if (ip==null || ip.length()==0 || "unknown".equalsIgnoreCase(ip)) {
ip=request.getHeader("Proxy-Client-IP");
}
if (ip==null || ip.length()==0 || "unknown".equalsIgnoreCase(ip)) {
ip=request.getHeader("WL-Proxy-Client-IP");
}
if (ip==null || ip.length()==0 || "unknown".equalsIgnoreCase(ip)) {
ip=request.getRemoteAddr();
}
if (ip !=null && ip.length() > 0) {
String[] ips=ip.split(",");
for (int i=0; i < ips.length; i++) {
if (!"unknown".equalsIgnoreCase(ips[i])) {
ip=ips[i];
break;
}
}
}
return ip;
}
/**
* 国际化获得语言内容
*
* @param key
* 语言key
* @param args
* @param argsSplit
* @param defaultMessage
* @param locale
* @return
*/
public static String getLanguage(String key, String args, String argsSplit,
String defaultMessage, String locale) {
String language="zh";
String contry="cn";
String returnValue=defaultMessage;
if (!StringUtil.isEmpty(locale)) {
try {
String[] localeArray=locale.split("_");
language=localeArray[0];
contry=localeArray[1];
} catch (Exception e) {
}
}
try {
ResourceBundle resource=ResourceBundle.getBundle("lang.resource",
new Locale(language, contry));
returnValue=resource.getString(key);
if (!StringUtil.isEmpty(args)) {
String[] argsArray=args.split(argsSplit);
for (int i=0; i < argsArray.length; i++) {
returnValue=returnValue.replace("{" + i + "}",
argsArray[i]);
}
}
} catch (Exception e) {
}
return returnValue;
}
}
?
到制作免费投票系统的话,首先自己要懂起码的编程,然后在网上查看各种资料,其实也蛮简单的,现在网上都有许多开源的免费投票系统代码可以学习的,也可以直接使用的,小编自己就有一套免费投票系统的代码,现在分享出来给大家学习下,如果你不的编程小白的话你就看可以直接把代码封包制作成免费投票系统了。
<html>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=投票系统” />
<META HTTP-EQUIV=”pragma” CONTENT=”no-cache”>
<META HTTP-EQUIV=”Cache-Control” CONTENT=”no-cache, must-revalidate”>
<META HTTP-EQUIV=”expires” CONTENT=http://www.aivote.com/ ”0″>
<meta http-equiv=”Content-Type” content=”text/html; charset=gb2312″>
</head>
<script language=”http://www.aivtp.com/4423.html javascript”>
function result(){
window.opener=’anyone’;
window.close();
}
</script>
<input name=’Action’ type=’hidden’ value=’Vote’>
<input name=’tj’http://www.aivtp.com/ type=”submit” value=”确认投票”>
</form></body>
</html>
这里要友情提示下,这套代码大家虽然简单,但是你如果是小白的话建议找懂的人给你看下,顺便改成你自己需要的投票系统,还可以在代码内添加验证码的代码或者短信验证码,这个可以根据自己需求来决定。
于艺术生来说
色彩可能是生活的百分之八十
好的配色
?是任何作品能够成功的关键
今天给大家的福利
“一份超全面的色彩网站”
快往下康康吧~~
· 正 · 文 · 来 · 啦 ·
1、COLORWISE
直通车:https://colorwise.io/
有大量的色彩搭配模板,大家可以挑选参考,对于作品集排版配色选择是个不错的网站。在Product Hunt中搜索投票最多的产品。
2、Color Hunt
直通车:https://colorhunt.co/
我们喜欢亲切的称呼它为:颜色狩猎,非常生动形象了有木有。Color Hunt是一个免费开放的色彩灵感平台,拥有数千种时尚的手工挑选调色板。
3、HTML Color Codes
直通车:https://htmlcolorcodes.com/
这个网站可以直接获取HTML颜色代码、十六进制颜色代码、RGB值和HSL值。
4、Duotones Effect Generator
直通车:https://medialoot.com/duotones/
双色调效果发生器,十几种经典双色调可选,如今撞色超级流行,这个网站可以多多参考。
5、Generate — Coolors.co
直通车:https://coolors.co/
超快的配色方案发生器,可以在几秒钟之内建立、保持和分享完美的调色板
6、Colorable
直通车:https://colorable.jxnblk.com/
颜色对比器。
对比度是使对象(或其在图像或显示器中的表示)可区分的亮度或颜色的差异。在对现实世界的视觉感知中,对比度由对象和同一视野内的其他对象的颜色和亮度的差异确定。
7、HueSnap
直通车:https://www.huesnap.com/
也是可以快速建立调色板的网站
8、Eva Design System
直通车:https://eva.design/
可定制的设计系统可轻松适应你的品牌。适用于Sketch with Mobile和Web组件库。
自由和开放源码。
9、Grabient
直通车:https://www.grabient.com/
渐变色UI配色大全,还可以自由添加。
10、Color Designer
直通车:https://colordesigner.io/
通过颜色选择器选择一个基础颜色,其他就交个它来处理啦。
11、Color Lisa
直通车:http://colorlisa.com/
来自世界上最伟大的艺术家的调色板杰作。
12、Color
直通车:https://www.canva.com/colors/
为任何项目寻找完美的颜色工具和资源。从调色板到你可能想要了解的有关颜色的所有内容。
13、Khroma
直通车:http://khroma.co/
设计师的AI颜色工具:发现,搜索和保存您喜爱的颜色组合。
14、Cool Backgrounds
直通车:https://coolbackgrounds.io/
Cool Backgrounds是一系列工具,可为博客,社交媒体和网站创建引人注目的彩色图像。除了背景,生成的图像可以用作桌面壁纸或裁剪为手机壁纸。
15、Eggradients
直通车:https://www.eggradients.com/
设计每年都在发展。最重要的设计,颜色,开始发展。我们准备了一个包含+200渐变背景颜色的渐变色调。
16、ColorKit
直通车:https://colorkit.io/
是一款很好用的颜色混合器
17、Color Leap - History’s Palettes
直通车:https://colorleap.app/home
选择时代,看历史颜色。
18、ColorSpace
直通车:https://mycolor.space/
19、Colors & Fonts
直通车:https://www.colorsandfonts.com/
20、WebGradients
直通车:https://webgradients.com/
WebGradients 是180个线性渐变的免费集合,你可以将其用作网站任何部分的内容背景。轻松复制CSS3 crossbrowser代码并立刻使用它!
20、中国色彩
直通车:http://zhongguose.com/
中国色彩网 是中国传统色彩的免费集合,当你选中一个色彩名称时,网站背景则会变为该色,并会出现该色不同格式的代码。
*请认真填写需求信息,我们会在24小时内与您取得联系。