关于JavaWeb验证码(数字)登入界面设计

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

目录

题目:

代码:

1.loginForm.jsp(登入界面)

2.validate.jsp(验证码生成)

3.ValidateServlet.java(Servlet文件,处理验证码是否正确)

4.web.xml(配置Servlet文件才能运行)

效果截图:

登入界面:

登入成功:

登入失败:

总结


题目:

       关于Javaweb的登入界面设置验证码,数字类型的验证,有登入界面loginForm.jsp,具有刷新验证码效果,生成验证码界面validate.jsp,Servlet文件ValidateServlet.java,处理验证码是否正确并返回结果,其次web.xml文件为Servlet的配置,让Servlet正常运行,最后测试验证。

代码:

1.loginForm.jsp(登入界面)

<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>




title



    
	欢迎登入本系统
请输入账号:
请输入密码:
验证码: 看不清楚 看不清,换一张

2.validate.jsp(验证码生成)

<%@ page language="java"
    import="java.awt.*"
    import="java.awt.image.BufferedImage"
    import="java.util.*"
    import="javax.imageio.ImageIO"
    pageEncoding="GB2312"
 %>


	<%
	response.setContentType("image/jpeg;charsert=utf-8");//关键,防止图片变成乱码
	 response.setHeader("Cache-Control","no-cache");
	//在内存中创建图像
	int width=60,height=20;
	BufferedImage image=new BufferedImage(width,height,BufferedImage.TYPE_INT_RGB);
	//获取笔画
	Graphics g=image.getGraphics();
	//设置背景
	g.setColor(new Color(200,200,200));
	g.fillRect(0, 0, width, height);
	//随机产生的验证码(4位数)
	Random rnd=new Random();
	int randNum=rnd.nextInt(8999)+1000;
	String randStr=String.valueOf(randNum);
	//将验证码存入session
	session.setAttribute("randStr",randStr);
	//将验证码显示到图像中
	g.setColor(Color.black);
	g.setFont(new Font(" ",Font.PLAIN,20));
	g.drawString(randStr, 10, 17);
	//随机产生100个干扰点,是图像中的验证码不易被其他程序探测到
	for(int i=0;i<100;i++)
	{
		int x=rnd.nextInt(width);
		int y=rnd.nextInt(height);
		g.drawOval(x, y, 1, 1);
	}
	//输出到图像页面
	ImageIO.write(image,"JPEG",response.getOutputStream());
	out.clear();
	out=pageContext.pushBody();
	%>
	
	

3.ValidateServlet.java(Servlet文件,处理验证码是否正确)

提示:这里个文件,还可以处理密码和账号是否正确,然后再决定成功登入系统页面。

package beans;

import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.http.HttpSession;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@WebServlet("/ValidateServlet")
public class ValidateServlet extends HttpServlet {
	private static final long serialVersionUID = 1L;
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		// TODO Auto-generated method stub
	String code=request.getParameter("code");
		HttpSession session=request.getSession();
		String randStr=(String)session.getAttribute("randStr");
		response.setCharacterEncoding("gb2312");
		PrintWriter out=response.getWriter();
		if(!code.equals(randStr))
		{
			out.println("验证码错误!");
			
		}
		else
		{
			out.println("验证码正确!跳转到longinserlet...");
		}
		
		
	}

}

4.web.xml(配置Servlet文件才能运行)

提示:只看ValidateServlet.java文件,其它的是多余出来的。

关于JavaWeb验证码(数字)登入界面设计_第1张图片

 

以下文件中, beans.ValidateServlet,beans是包名,ValidateServlet是java的类名,其它的不变。



  T2
  
    index.html
    index.htm
    index.jsp
    default.html
    default.htm
    default.jsp
  
  
  
    ValidateServlet
    beans.ValidateServlet
  
  
    ValidateServlet
    /servlet/ValidateServlet
  

效果截图:

登入界面:

关于JavaWeb验证码(数字)登入界面设计_第2张图片

登入成功:

关于JavaWeb验证码(数字)登入界面设计_第3张图片

登入失败:

关于JavaWeb验证码(数字)登入界面设计_第4张图片

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了关于JavaWeb验证码(数字)登入界面设计。

你可能感兴趣的:(JavaWeb设计,servlet,java,javascript)