Jfinal驗證碼功能

//驗證碼工具類javascript

import java.awt.Color;
import java.awt.Font;
import java.awt.Graphics;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.security.MessageDigest;
import java.util.Random;

import javax.imageio.ImageIO;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.Cookie;

import com.jfinal.core.Controller;
import com.jfinal.kit.StringKit;
import com.jfinal.render.Render;

public class MyCaptchaRender extends Render {

       private static final long serialVersionUID = -7599510915228560611L;
     
        private static final String[] strArr = {"3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "J", "K", "M", "N", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y"};
         
        private static String randomCodeKey = "JFINAL_JLHHWH_Key";
        private static boolean caseInsensitive = true;
         
        private int img_width = 85;
        private int img_height = 20;
        private int img_randNumber = 6;
         
        public MyCaptchaRender() {
        }
         
        public MyCaptchaRender(String randomKey) {
            if (StringKit.isBlank(randomKey))
                throw new IllegalArgumentException("randomKey can not be blank");
            randomCodeKey = randomKey;
        }
         
        public MyCaptchaRender(int width, int height, int count, boolean isCaseInsensitive) {      
            if(width <=0 || height <=0 || count <=0)
            {
                throw new IllegalArgumentException("Image width or height or count must be > 0");
            }
            this.img_width = width;
            this.img_height = height;
            this.img_randNumber = count;
            caseInsensitive = isCaseInsensitive;
        }
         
        public MyCaptchaRender(String randomKey,int width, int height, int count, boolean isCaseInsensitive) {
            if (StringKit.isBlank(randomKey))
                throw new IllegalArgumentException("randomKey can not be blank");
            randomCodeKey = randomKey;
             
            if(width <=0 || height <=0 || count <=0)
            {
                throw new IllegalArgumentException("Image width or height or count must be > 0");
            }
            this.img_width = width;
            this.img_height = height;
            this.img_randNumber = count;
            caseInsensitive = isCaseInsensitive;
        }
         
        public void render() {
            BufferedImage image = new BufferedImage(img_width, img_height, BufferedImage.TYPE_INT_RGB);
            String vCode = drawGraphic(image);
            vCode = encrypt(vCode);
            Cookie cookie = new Cookie(randomCodeKey, vCode);
            cookie.setMaxAge(-1);
            cookie.setPath("/");
            response.addCookie(cookie);
            response.setHeader("Pragma","no-cache");
            response.setHeader("Cache-Control","no-cache");
            response.setDateHeader("Expires", 0);
            response.setContentType("image/jpeg");
             
            ServletOutputStream sos = null;
            try {
                sos = response.getOutputStream();
                ImageIO.write(image, "jpeg",sos);
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
            finally {
                if (sos != null)
                    try {sos.close();} catch (IOException e) {e.printStackTrace();}
            }
        }
    
        private String drawGraphic(BufferedImage image){
            // 獲取圖形上下文
            Graphics g = image.createGraphics();
            // 生成隨機類
            Random random = new Random();
            // 設定背景色
            g.setColor(getRandColor(200,250));
            g.fillRect(0, 0, img_width, img_height);
            // 設定字體
            g.setFont(new Font("Times New Roman", Font.PLAIN, 18));
    
            // 隨機產生155條幹擾線,使圖象中的認證碼不易被其它程序探測到
            g.setColor(getRandColor(160, 200));
            for (int i = 0; i < 155; i++) {
                int x = random.nextInt(img_width);
                int y = random.nextInt(img_height);
                int xl = random.nextInt(12);
                int yl = random.nextInt(12);
                g.drawLine(x, y, x + xl, y + yl);
            }
    
            // 取隨機產生的認證碼(img_randNumber位數字)
            String sRand = "";
            for (int i = 0; i < img_randNumber; i++) {
                String rand = String.valueOf(strArr[random.nextInt(strArr.length)]);
                sRand += rand;
                // 將認證碼顯示到圖象中
                g.setColor(new Color(20 + random.nextInt(110), 20 + random.nextInt(110), 20 + random.nextInt(110)));
                // 調用函數出來的顏色相同,多是由於種子太接近,因此只能直接生成
                g.drawString(rand, 13 * i + 6, 16);
            }
    
            // 圖象生效
            g.dispose();
             
            return sRand;
        }
         
        /*
         * 給定範圍得到隨機顏色
         */
        private Color getRandColor(int fc, int bc) {
            Random random = new Random();
            if (fc > 255)
                fc = 255;
            if (bc > 255)
                bc = 255;
            int r = fc + random.nextInt(bc - fc);
            int g = fc + random.nextInt(bc - fc);
            int b = fc + random.nextInt(bc - fc);
            return new Color(r, g, b);
        }
         
        private static final String encrypt(String srcStr) {
            try {
                String result = "";
                MessageDigest md = MessageDigest.getInstance("MD5");
                byte[] bytes = md.digest(srcStr.getBytes("utf-8"));
                for(byte b:bytes){
                    String hex = Integer.toHexString(b&0xFF).toUpperCase();
                    result += ((hex.length() ==1 ) ? "0" : "") + hex;
                }
                return result;
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
        }
    
        public static boolean validate(Controller controller, String inputRandomCode) {
            if (StringKit.isBlank(inputRandomCode))
                return false;
            try {
                if(caseInsensitive)
                    inputRandomCode = inputRandomCode.toUpperCase();
                inputRandomCode = encrypt(inputRandomCode);
                return inputRandomCode.equals(controller.getCookie(randomCodeKey));
            } catch (Exception e) {
                e.printStackTrace();
                return false;
            }
        }
}java

 

//Controller類(調用該方法來產生一個新的驗證碼)cookie

public class CaptchaController extends Controller {
    /**
    * @Title: index
    * @Description: TODO(產生一個驗證碼)
    * void
    */
    public void index(){
        render(new MyCaptchaRender(60,22,4,true));
    }dom

 

//路由配置函數

public class FrontRoutes extends Routes
{
    public void config()
    {
            add("/captcha",CaptchaController.class);
    }工具

 

 

//頁面代碼字體

<body>this

<img src="${path!}/captcha/index" id="checkCode" style="cursor: pointer;height: 70%;width: 80%;"  title="點擊刷新驗證碼" />ip

</body>utf-8

<script type="text/javascript">

//點擊更換驗證碼
$(function(){
    $("#checkCode").click(function(){
        $(this).attr("src","${path!}/captcha?d="+Math.random().toString());
    });
});
</script>

 

//效果圖

 

相關文章
相關標籤/搜索