怎么用imageIO圖像流實現驗證碼效果

這篇文章主要介紹“怎么用imageIO圖像流實現驗證碼效果”,在日常操作中,相信很多人在怎么用imageIO圖像流實現驗證碼效果問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么用imageIO圖像流實現驗證碼效果”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

創(chuàng)新互聯專業(yè)為企業(yè)提供城關網站建設、城關做網站、城關網站設計、城關網站制作等企業(yè)網站建設、網頁設計與制作、城關企業(yè)網站模板建站服務,10年城關做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。

package cn.images;

import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.util.Random;

public class CapcahaDemo {
    public static void main(String[] args) throws Exception {
        //驗證碼的長寬
        int len = 4;
        int width = len * 26;
        int height =50;
        //驗證碼中的數字 字母
        String letter = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
        var rand = new Random();
        StringBuilder sub = new StringBuilder();
        var cc = new BufferedImage(width, height, BufferedImage.TYPE_INT_ARGB);
        var g= cc.createGraphics();
        setRenderingHint(g);
        //背景的隨機把顏色
        g.setColor(new Color(rand.nextInt(26)+220,rand.nextInt(26)+220,rand.nextInt(26)+220));
        //背景 填充矩形 位置 寬高
        g.fillRect(0,0,width,height);
        //字體顏色
        var c = new Color(rand.nextInt(256),rand.nextInt(256),rand.nextInt(256));
        g.setColor(c);
        //生成四個隨機驗證碼內容
        for(int i = 0;i<len;i++){
            //將其轉換成字符串(返回指定索引處的char值。索引范圍是從0到length() - 1 (返回一個大于0小于letter的長度的隨機數))
            //就是從letter中隨機取出一個
            String str  = String.valueOf(letter.charAt(rand.nextInt(letter.length())));
            sub.append(str);
            //驗證碼中內容的位置
            var x = i*25+5;
            var y = 35;
            //設置文字旋轉角度
            double radianPercent = Math.PI*(rand.nextInt(35)/180D);
            if(rand.nextBoolean())
                radianPercent = -radianPercent;
            //文字正向旋轉
            g.rotate(radianPercent,x,y);
            //驗證碼內容的字體樣式  粗細正常   字體大小[20-40)
            g.setFont(new Font("微軟雅黑",Font.PLAIN,rand.nextInt(20)+20));
            g.drawString(str,x,y);
            //文字反向旋轉
            g.rotate(-radianPercent,x,y);

        }
        //干擾文件
        for(int i=0;i<len*10;i++) {
            var x = rand.nextInt(width);
            var y = rand.nextInt(height);
            String str = String.valueOf(letter.charAt(rand.nextInt(letter.length())));
            double radianPercent = Math.PI * (rand.nextInt(35) / 180D);
            //if (rand.nextBoolean())
            //    radianPercent = -radianPercent;
            //g.rotate(radianPercent, x, y);

            c = new Color(rand.nextInt(256), rand.nextInt(256), rand.nextInt(256),rand.nextInt(30)+60);
            g.setColor(c);

            g.setFont(new Font("微軟雅黑", Font.PLAIN, rand.nextInt(10) + 10));
            g.drawString(str, x, y);
        }

        // 干擾正統曲線
        //字體顏色相同
        g.setColor(new Color(rand.nextInt(255),rand.nextInt(255),rand.nextInt(255)));

        int yy = rand.nextInt(35)+15;
        int hh = rand.nextInt(20)+10;
        int aa = rand.nextInt(60)+20;

        for(int x= 0; x<width;x++){
            int y = (int)(yy+ hh * Math.sin(x*Math.PI/aa));

            g.fillOval(x,y,5,5);
        }

        g.dispose();

        ImageIO.write(cc,"png",new File("cc.png"));

        Runtime.getRuntime().exec("cmd /k start cc.png");
    }
//設置線條平滑
    public static void setRenderingHint(Graphics2D g) {
        g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
        g.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_GASP);
        g.setRenderingHint(RenderingHints.KEY_STROKE_CONTROL, RenderingHints.VALUE_STROKE_DEFAULT);
    }

    public static Font getRandFont(int end, int start) {
        Random rand = new Random();
        Font font = null;
        if(rand.nextBoolean()){
            font = new Font("微軟雅黑",Font.PLAIN , rand.nextInt(end) + start);

        }else {
            try{
                Font f = Font.createFont(Font.TRUETYPE_FONT,new File("fonts/zh264hfyh.ttf"));
                font = f.deriveFont(Font.PLAIN,rand.nextInt(end)+ start);
            }catch (Exception e){
                e.printStackTrace();
            }
        }
        return font;
    }

}

到此,關于“怎么用imageIO圖像流實現驗證碼效果”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯網站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

分享標題:怎么用imageIO圖像流實現驗證碼效果
分享URL:http://muchs.cn/article30/pidopo.html

成都網站建設公司_創(chuàng)新互聯,為您提供網站制作、品牌網站制作、做網站、網站收錄網站內鏈、外貿建站

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都做網站