小言_互联网的博客

Java>Response对象设置响应行、头、体及网页验证码图片刷新功能代码

256人阅读  评论(0)

Response对象

    功能:设置响应消息

        1.设置响应行:

            1.格式:HTT/1.1 200 ok

            2.设置状态码:setStatus(int sc)

        2.设置响应头:setheader(String name,String value)

        3.设置响应体:

            使用步骤:

                1.获取输出流

                    1.字符输出流:PrintWrite getWrite()

                    2.字节输出流:ServletOutputString getOutputString()

                2.使用输出流,将数据输出到客户端浏览器

案例:

1.完成重定向:

        重定向:资源跳转的方式

        代码实现:        

//简单的重定向方法
response.sendRedirect("/Tomcat/chongdingxiangDemo2");

    forward 和 redirect 区别

    重定向的特点: redirect

        1.地址栏发生变化

        2.重定向可以访问其他站点(服务器)的资源

        3.重定向是两次请求。不能使用request对象共享数据

    转发向的特点: forward

        1.地址栏不发生变化

        2.转发只能访问当前服务器下的资源

        3.转发是一次请求,可以使用request对象来共享数据

    路径的写法:

        1.路径的分类:

            1.相对路径:通过相对路径不可以确定唯一资源

                规则:找到当前资源和目标资源之间的相对位置关系

                    ./:当前目录

                    ../:后退一级目录

        2.绝对路径:通过绝对路径可以确实唯一资源

            目录:判断定义的路径是给谁用的

                给客户端浏览器使用:需要加虚拟目录

                给服务器使用:不需要加虚拟目录

2.服务器输出字符数据到浏览器:

    步骤:

        1.获取字符输出流

        2.输出数据

    中文乱码原因:编解码使用的字符集不一致     

        1. PrintWriter pw = response.getWriter(); //获取的流的默认编码是ISO-8859-1

        2.设置该流的默认编码

        3.告诉浏览器响应体使用的编码

//简单的形式,设置编码,是在获取流对象之前设置
response.setContentType("text/html;charset=utf-8");
//获取流之前,设置流的默认编码:ISO-8859-1 设置为:utf-8
        //response.setCharacterEncoding("utf-8");

        //告诉浏览器,服务器发送的消息体数据的编码,建议浏览器使用该编码解码
        //response.setHeader("content-type","text/html;charset=utf-8");

        //简单的形式,设置编码
        response.setContentType("text/html;charset=utf-8");

        //1.获取字符输出流
        PrintWriter pw = response.getWriter();
        //2.输出数据
        //pw.write("<h1>hello response</h1>");
        pw.write("<h1>您好 response</h1>");

3.服务器输出字节数据到浏览器:

response.setContentType("text/html;charset=utf-8");

//1.获取字节输出流
ServletOutputStream sos = response.getOutputStream();
//2.输出数据
sos.write("你好,response".getBytes("utf-8"));

4.验证码:

    1.本质:图片

    2.目的:防止恶意表单注册

代码:

定义验证码刷新页面:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>验证码刷新</title>
    <script>
        /*
            分析:
                点击超链接或者图片,需要换一张
                1.给超链接和图片绑定点击事件
                2.重新设置图片的src属性值
         */
        window.onload = function () {
            //1.给超链接和图片绑定点击事件
            var img = document.getElementById("checkCode");
            //2.绑定点击事件
            img.onclick = function () {
                //加时间戳
                var date = new Date().getTime();
                img.src = "/Tomcat/checkCodeServlet?" + date;
            }

            var a = document.getElementById("change");
            //2.绑定点击事件
            a.onclick = function () {
                //加时间戳
                var date = new Date().getTime();
                img.src = "/Tomcat/checkCodeServlet?" + date;
            }
        }
    </script>
</head>
<body>
    <img id="checkCode" src="/Tomcat/checkCodeServlet" />
    <a id="change" href="">看不清换一张</a>
</body>
</html>

定义一个类:

package cn.itcast.web.yanzhengma;

import javax.imageio.ImageIO;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.IOException;
import java.util.Random;

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

        //1.创建一对象,在内存中图片(验证码图片对象)
        BufferedImage image = new BufferedImage(width,height,BufferedImage.TYPE_3BYTE_BGR);

        //2.美化图片
            //2.1填充背景色
            Graphics g = image.getGraphics(); //画笔对象
            g.setColor(Color.pink);//设置画笔颜色
            g.fillRect(0,0,width,height);

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

            String str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
            //生成随机角标
            Random ran  = new Random();

            for (int i = 1; i <= 4; i++) {
                int index = ran.nextInt(str.length());
                //获取字符
                char ch = str.charAt(index);//随机字符
                //2.3写验证码
                g.drawString(ch+"",width/5*i,height/2);
            }

            //2.4画干扰线
            g.setColor(Color.green);
            //随机生成坐标点
            for (int i = 0; i <= 10; i++) {
                int x1 = ran.nextInt(width);
                int x2 = ran.nextInt(width);
                int y1 = ran.nextInt(height);
                int y2 = ran.nextInt(height);
                g.drawLine(x1,y1,x2,y2);
            }

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

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request,response);
    }
}

 

 


转载:https://blog.csdn.net/qq_36050720/article/details/101108689
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场