1.style.css
@import url('reset.css');
@import url('plug-ins/customScrollbar.min.css');
.activeNav{
background-color: #333e48 ;
}
.panel-ft{
margin-top: -20px;
}
.login-page {
background: url(../imgs/bg9.png) no-repeat fixed;
overflow: hidden;
background-size: cover;
height: 100%;
}
.authCardImg{
width:200px;height:120px;
}
.login-contain {
width: 340px;
height: auto;
position: relative;
left: 77%;
top: 50%;
transform: translate(-50%, -50%);
overflow: hidden;
box-shadow: 0 5px 20px rgba(19, 32, 48, 0.25);
background: #ffffff;
/* border-bottom: 5px #4bcf99 solid;
*/ border-radius: 2px;
}
.login-contain header {
padding: 10px 0;
text-align: center;
color: #97a4b1;
font-size: 14px;
border-bottom: 1px #4bcf99 solid;
letter-spacing: 5px;
}
.login-contain header h1 {
font-weight: normal;
margin-bottom: 5px;
color: #4f5f6f;
}
.login-contain header p {
text-transform: uppercase;
font-size: 12px;
color: #d7dde4;
}
.login-contain .form-content {
margin: 40px 50px;
}
.login-contain .form-content li {
margin-bottom: 15px;
overflow: hidden;
}
.login-contain .form-content li:last-child {
margin: 0;
}
.login-contain .form-content li .form-control {
background: none;
border-color: #d7dde4;
}
.login-contain .form-content li .btm-info {
font-size: 12px;
text-align: center;
color: #d7dde4;
}
.login-contain .form-content li .tips {
display: none;
margin-top: 5px;
font-size: 12px;
color: #9ca2a8;
}
.login-contain .form-content li .tips mark {
color: inherit;
}
a {
color: #969696;
}
a:hover {
color: #33be85;
}
a:active {
color: #33be85;
}
2.login.html
验证码demo
登录
-
-
-
-
3.ImageController
package com.project.controller;
import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;
import javax.imageio.ImageIO;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import redis.clients.jedis.Jedis;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.project.utils.RedisUtil;
@Controller
@RequestMapping("/image/")
public class ImageController extends BaseController{
@RequestMapping("genCode")
public void genCZCode(HttpServletRequest request, HttpServletResponse response){
logger.info("genCode参数 : " + JSON.toJSONString(request.getParameterMap()));
Jedis jedis =RedisUtil.getJedis();
try {
System.setProperty("java.awt.headless", "true");
// 响应头信息
response.setHeader("Pragma", "No-Cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expries", 0);
String uuid = request.getParameter("uuid");
// 随机数生成类
Random random = new Random();
// 定义验证码的位数
int size = 5;
// 定义变量保存生成的验证码
String vCode = "";
char c;
// 产生验证码
for (int i = 0; i < size; i++) {
// 产生一个26以内的随机整数
int number = random.nextInt(26);
// 如果生成的是偶数,则随机生成一个数字
if (number % 2 == 0) {
c = (char) ('0' + (char) ((int) (Math.random() * 10)));
// 如果生成的是奇数,则随机生成一个字母
} else {
c = (char) ((char) ((int) (Math.random() * 26)) + 'A');
}
vCode = vCode + c;
}
// 保存生成的5位验证码
jedis.set(uuid+"-code", vCode);
System.out.println(uuid+"-code---------"+vCode);
jedis.expire(uuid+"-code", 600);
// 验证码图片的生成
// 定义图片的宽度和高度
int width = (int) Math.ceil(size * 20);
int height = 50;
BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);
// 获取图片的上下文
Graphics gr = image.getGraphics();
// 设定图片背景颜色
gr.setColor(Color.WHITE);
gr.fillRect(0, 0, width, height);
// 设定图片边框
gr.setColor(Color.GRAY);
gr.drawRect(0, 0, width - 1, height - 1);
// 画十条干扰线
for (int i = 0; i < 5; i++) {
int x1 = random.nextInt(width);
int y1 = random.nextInt(height);
int x2 = random.nextInt(width);
int y2 = random.nextInt(height);
gr.setColor(randomColor());
gr.drawLine(x1, y1, x2, y2);
}
// 设置字体,画验证码
gr.setColor(randomColor());
gr.setFont(randomFont());
gr.drawString(vCode, 10, 22);
// 图像生效
gr.dispose();
// 输出到页面
ImageIO.write(image, "PNG", response.getOutputStream());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally {
RedisUtil.returnResource(jedis);
}
}
@RequestMapping("validateCode")
@ResponseBody
public String validateCode(HttpServletRequest request, HttpServletResponse response){
logger.info("validateCode参数 : " + JSON.toJSONString(request.getParameterMap()));
JSONObject result = new JSONObject();
Jedis jedis = RedisUtil.getJedis();
try {
String uuid = request.getParameter("uuid");
String code = request.getParameter("code");
String cacheCode = jedis.get(uuid + "-code");
if(StringUtils.isEmpty(code) || StringUtils.isEmpty(cacheCode)){
result.put("status", "false");
result.put("msg", "验证码错误");
}else if(code.equalsIgnoreCase(cacheCode)){
result.put("status", "true");
result.put("msg", "验证通过");
}else{
result.put("status", "false");
result.put("msg", "验证码错误");
}
} catch (Exception e) {
e.printStackTrace();
result.put("status", "false");
}finally {
RedisUtil.returnResource(jedis);
}
return result.toJSONString();
}
// 生成随机的颜色
private Color randomColor() {
int red = r.nextInt(150);
int green = r.nextInt(150);
int blue = r.nextInt(150);
return new Color(red, green, blue);
}
private String[] fontNames = { "宋体", "华文楷体", "黑体", "微软雅黑", "楷体_GB2312" };
private Random r = new Random();
// 生成随机的字体
private Font randomFont() {
int index = r.nextInt(fontNames.length);
String fontName = fontNames[index];// 生成随机的字体名称
int style = r.nextInt(4);
int size = r.nextInt(3) + 24; // 生成随机字号, 24 ~ 28
return new Font(fontName, style, size);
}
}
4.BaseController
@RequestMapping(value = "dologin")
@ResponseBody
public String login(HttpServletRequest request){
logger.info("login参数:" + JSON.toJSONString(request.getParameterMap()));
JSONObject result = new JSONObject();
Jedis jedis = RedisUtil.getJedis();
try {
result.put("status", "success");
String uuid = request.getParameter("uuid");
String code = request.getParameter("code");
String cacheCode = jedis.get(uuid + "-code");
if(StringUtils.isEmpty(code) ){
result.put("status", "fail");
result.put("msg", "输入验证码错误");
return result.toJSONString();
}else if( StringUtils.isEmpty(cacheCode) ){
result.put("status", "fail");
result.put("msg", "验证码异常");
return result.toJSONString();
}else if(StringUtils.isEmpty(uuid)){
result.put("status", "fail");
result.put("msg", "验证码异常唯一码错误");
return result.toJSONString();
}else if(code.equalsIgnoreCase(cacheCode)){
result.put("msg", "验证通过");
}else{
result.put("status", "fail");
result.put("msg", "验证码错误");
return result.toJSONString();
}
String account = request.getParameter("account");
String pwd = request.getParameter("pwd");
String pwdMd5 = MD5Encoder.encode(pwd);
User sysUser = userService.loginSys(account, pwdMd5);
if(sysUser == null){
result.put("status", "fail");
result.put("msg", "账号或密码错误");
return result.toJSONString();
}
if(!sysUser.getIsenabled()){
result.put("status", "fail");
result.put("msg", "账号已禁用");
return result.toJSONString();
}
sysUser.setPassword(null);
request.getSession().setAttribute("user", sysUser);
return result.toJSONString();
} catch (Exception e) {
e.printStackTrace();
result.put("status", "fail");
result.put("msg", "系统异常,请重新登录");
return result.toJSONString();
} finally{
RedisUtil.returnResource(jedis);
}
}