效果:网页验证码,每过去5s生成一张新的7位验证码图片。
结果图片:
提示:以下是本篇文章正文内容:
类似于我们日常生活中的验证码,比较通用。在用户登录的时候可以使用的到。
//方法:生成8位随机数,不够补0,最后返回一个字符串。------线程安全
private String makeNum() {
Random random = new Random();
String num = random.nextInt(9999999) + "";//生成随机数
StringBuffer sb = new StringBuffer();
for (int i = 0; i < 7 - num.length(); i++) {
sb.append("0");
}
num = sb.toString() + num;//注意2:0拼接子啊前面
return num;
}
注意:这里只有ImageServlet方法的实现,三部曲当中只有第一步,注册servlet和配置映射,部署tomcat服务器在此没有展示。
public class ImageServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//生成网站验证码:
//1.让浏览器5s自动刷新一次
resp.setHeader("refresh", "5");
//2.在内存中创建一个图片
//3.得到图片
//4.设置图片的背景颜色
//5.给图片写数据
BufferedImage image = new BufferedImage(80, 20, BufferedImage.TYPE_INT_RGB);
Graphics2D g = (Graphics2D) image.getGraphics();
g.setColor(Color.white);//注意1:填充颜色
g.fillRect(0, 0, 80, 20);//矩形填充
g.setColor(Color.BLUE);
g.setFont(new Font(null, Font.BOLD, 20));
g.drawString(makeNum(), 0, 20);
//6.告诉浏览器,这个请求,用图片的什么形式打开
//7.不让浏览器进行缓存
resp.setContentType("image/jpeg");
resp.setDateHeader("expires", -1);
resp.setHeader("Cache-control", "no-cache");
resp.setHeader("Pragma", "no-cache");
//8.把图片打开(写给浏览器)
ImageIO.write(image, "jpg", resp.getOutputStream());
}
//方法:生成8位随机数,不够补0,最后返回一个字符串。------线程安全
private String makeNum() {
Random random = new Random();
String num = random.nextInt(9999999) + "";//生成随机数
StringBuffer sb = new StringBuffer();
for (int i = 0; i < 7 - num.length(); i++) {
sb.append("0");
}
num = sb.toString() + num;//注意2:0拼接子啊前面
return num;
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doPost(req, resp);
}
}
提示:这里对文章进行总结:
不断地练习,进而熟练,从而掌握。