189 8069 5689

JavaWeb中怎么利用Session实现一次性验证码功能

JavaWeb中怎么利用Session实现一次性验证码功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

创新互联专注于巴楚企业网站建设,成都响应式网站建设公司,商城网站定制开发。巴楚网站建设公司,为巴楚等地区提供建站服务。全流程专业公司,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务

表单

请输入验证码:

载入页面时,会自动请求getCodeServlet,获取图片(验证码)。

getCodeServlet,产生验证码

@WebServlet("/getCodeServlet")public class GetCodeServlet extends HttpServlet {  //验证码的宽、高  private static int WIDTH=80;  private static int HEIGHT=25;  //绘制背景  private void drawBg(Graphics g){    //rgb    g.setColor(new Color(128, 128, 128));    //绘制矩形。x,y,wigth,height    g.fillRect(0,0,WIDTH,HEIGHT);    //随机绘制100个干扰点    Random random=new Random();    for (int i=0;i<100;i++){      //产生(0,1)上的小数,*WIDTH|HEIGHT,再取整也行      int x=random.nextInt(WIDTH);      int y=random.nextInt(HEIGHT);      g.drawOval(x,y,1,1);      //干扰点的颜色也可以随机,随机产生red,green,blue即可      //g.setColor(new Color(red,green,blue));    }  }  //绘制验证码  private void drawCode(Graphics g,char[] code){    g.setColor(Color.BLACK);    //字体、样式(多个时竖线分隔)、字号    g.setFont(new Font("serif",Font.ITALIC|Font.BOLD,18));    //在不同位置绘制验证码字符,参数:要绘制的String、横、纵坐标。+""是为了char转String。    g.drawString(code[0]+"",1,17);    g.drawString(code[1]+"",16,15);    g.drawString(code[2]+"",31,18);    g.drawString(code[3]+"",46,16);  }  //随机产生4位验证码  private char[] getCode(){    String chars="0123456789QWERTYUIOPASDFGHJKLZXCVBNMqwertyuiopasdfghjklzxcvbnm";    char[] code=new char[4];    Random random=new Random();    for (int i=0;i<4;i++){      //[0,62)      int index= random.nextInt(62);      code[i]=chars.charAt(index);    }    return code;  }  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException {    HttpSession session = request.getSession();    ServletOutputStream sos = response.getOutputStream();    response.setContentType("image/jpeg");    //设置浏览器不缓存此图片    response.setHeader("Pragma","No-cache");    response.setHeader("Cache-Control","no-cache");    response.setDateHeader("Expires",0);    //创建内存图片    BufferedImage bufferedImage = new BufferedImage(WIDTH, HEIGHT, TYPE_INT_RGB);    Graphics g= bufferedImage.getGraphics();    char[] code=getCode();    //将验证码放到session域中。session对象要在提交响应之前获得    session.setAttribute("code",new String(code));    drawBg(g);    drawCode(g,code);    g.dispose();    //将图片输出到浏览器    ByteArrayOutputStream baos = new ByteArrayOutputStream();    ImageIO.write(bufferedImage,"JPEG",baos);    baos.writeTo(sos);    baos.close();    sos.close();  }  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {    doPost(request,response);  }}

loginServlet,处理表单

@WebServlet("/loginServlet")public class LoginServlet extends HttpServlet {  protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {    response.setContentType("text/html;charset=utf-8");    HttpSession session = request.getSession();    String trueCode= (String) session.getAttribute("code");    String code=request.getParameter("code");    if (code.equals(trueCode)){      response.getWriter().write("验证码正确");    }    else {      response.getWriter().write("验证码错误");    }  }  protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {    doPost(request,response);  }}

上面的处理方式要区分验证码的大小写。

不区分大小写:

//先转换为全大写|全小写,再判断    trueCode=trueCode.toLowerCase();    code=code.toLowerCase();    //trueCode=trueCode.toUpperCase();    //code=trueCode.toUpperCase();

关于JavaWeb中怎么利用Session实现一次性验证码功能问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。


本文标题:JavaWeb中怎么利用Session实现一次性验证码功能
文章链接:http://jkwzsj.com/article/jjphjj.html

其他资讯