后台系统通用验证码方案

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);
		}
	}






你可能感兴趣的:(实例)