JAVA --- 简单验证码的编写|js+html实现换一张验证码|看不清?换一张

简单验证码如何编写?

@WebServlet("/CheckCodeServlet")
public class CheckCodeServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
            int width = 100;
            int height = 50;

        //创建图片对象
        BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);

        //美化图片
        //1.填充背景色
        Graphics g = image.getGraphics(); //创建画笔对象
        g.setColor(Color.PINK);  //设置画笔颜色
        g.fillRect(0,0,width,height);  //从(0,0)点开始

        //2.画边框
        g.setColor(Color.BLACK);
        g.drawRect(0,0,width-1,height-1);

        //定义字符库
        String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqlstuvwxyz1234567890" ;

        //定义角标(即选中哪个字符)
        Random random = new Random();


        //选四个字符
        for(int i = 0; i < 4; i ++){
            int index = random.nextInt(str.length());
            char ch = str.charAt(index);  //charAt通过角标获取字符
            g.drawString(ch+"",width/5*(i+1),height/2);
        }

        //画干扰线
        g.setColor(Color.cyan);

        for(int x =0; x< 11; x++){
            int x1 = random.nextInt(width);
            int x2 = random.nextInt(width);
            int y1 = random.nextInt(height);
            int y2 = random.nextInt(height);
            g.drawLine(x1,y1,x2,y2);
        }



        //输出图片到页面
        ImageIO.write(image,"jpg",response.getOutputStream());
    }

如何使用编写好的验证码?


需求:单击页面的验证码图片或者超链接都可以更换随机生成的验证码


环境:html+js


代码:


<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Titletitle>
    <script>
        //给超链接和图片绑定单击事件,并且重新设定图片src的值
        function reImg() {
            var img = document.getElementById("checkcode");
            //2.绑定单击事件
            //加时间戳
            var date = new Date().getTime();
            img.src = "/day15/CheckCodeServlet?" + date;
        }
    script>
head>
<body>
    
     看不清?点此处换一张a>
body>
html>

TIPS:
1.时间戳的作用:浏览器有自动缓存的功能,所以不加时间戳的话,img的src属性就无法实现更改,加一个每次必定会不一样的属性,时间最合适不过。使用随机数属性也有可能会重复,所以使用时间戳最好。
2.超链接的href属性一开始不用" " (空) 的原因是,用空会导致页面刷新,那么之前填写的数据就消失了。


                                        感谢收阅      

你可能感兴趣的:(JAVA)