Java web resposne

response

1.响应消息:服务器端发送给客户端的数据              响应行:HTTP/1.1 200 OK
        1. 响应行
              1. 1xx:服务器就收客户端消息,但没有接受完成,等待一段时间后,发送1xx多状态码
              2. 2xx:成功。代表:200
              3. 3xx:重定向。代表:302(重定向),   304(访问缓存)    访问一个图片同一个地址就会缓存在浏览器
              4. 4xx:客户端错误。   404(请求路径没有对应的资源)          405:请求方式没有对应的doXxx方法
              5. 5xx:服务器端错误。代表:500(服务器内部出现异常)       
       2. 响应头
             1.. 常见的响应头:
                  1. Content-Type:服务器告诉客户端本次响应体数据格式以及编码格式
                  2. Content-disposition:服务器告诉客户端以什么格式打开响应体数据
                        1. in-line:默认值,在当前页面内打开            2.  attachment;filename=xxx:以附件形式打开响应体。文件下载
            3. 响应空行           4. 响应体:传输的数据

Response对象方法

        1.设置状态码:setStatus(int sc) 
        2. 设置响应头:setHeader(String name, String value) 

       3. 设置响应体:1. 字符输出流:PrintWriter getWriter()           2.字节输出流:ServletOutputStream getOutputStream()

        ServletOutputStream sos = response.getOutputStream();
        sos.write("你好".getBytes("utf-8"));

重定向

       1. 设置状态码为302          response.setStatus(302);
       2.设置响应头location        response.setHeader("location",  "转发地址");     重定向需要虚拟目录

            String contextPath = request.getContextPath();
            response.setStatus(302);
            response.setHeader("location",contextPath+"/demo02");

       1.简单的重定向方法         response.sendRedirect( "/转发地址" );

response.sendRedirect(contextPath+"/demo02");

       重定向的特点:redirect     1. 地址栏发生变化   2. 重定向可以访问其他站点(服务器)的资源
                                                 3. 重定向是两次请求。不能使用request对象来共享数据             与forward转发完全相反

设置响应编码

        1. PrintWriter pw = response.getWriter();             获取的流的默认编码是ISO-8859-1 因为是 tomcat 编写
        2.设置该流的默认编码   :                response.setCharacterEncoding("utf-8");     设置流的编码
        3.告诉浏览器响应体使用的编码  :   response.setHeader("content-type","text/html;charset=utf-8");   设置浏览器解码

        response.setCharacterEncoding("utf-8");  
        response.setHeader("content-type","text/html;charset=utf-8");
        PrintWriter writer = response.getWriter();
        writer.write("中国");

   4.简单的形式,设置编码,是在获取流之前设置    response.setContentType(  "text/html;  charset=utf-8"  );

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

路径写法

        1. 相对路径:通过相对路径不可以确定唯一资源               如:./ index.html  
                不以/开头,以.开头路径      ./:当前目录           ../:后退一级目录
         2. 绝对路径:通过绝对路径可以确定唯一资源
               1.如:http://localhost/day15/responseDemo2        /day15/responseDemo2           以/开头的路径

         规则:判断定义的路径是给谁用的?判断请求将来从哪儿发出
                1.给客户端浏览器使用:需要加虚拟目录(项目的访问路径)
                        2.建议虚拟目录动态获取:request.getContextPath()
                                1. <a>        2.<form>          3. 重定向...
                 2.给服务器使用:不需要加虚拟目录  :     转发路径

java 生成验证码


        int width = 100;
        int height = 50;

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

        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 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghigklmnopqrstuvwxyz0123456789";
        生成随机角标
        Random ran = new Random();

        for (int i = 1; i <= 4; i++) {
            int index = ran.nextInt(str.length());
            //获取字符
            char ch = str.charAt(index);//随机字符
            System.out.println(ch);
            //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());

 

解释一下这段代码function [params, bg_area, fg_area, area_resize_factor] = initializeAllAreas(im, params) % we want a regular frame surrounding the object avg_dim = sum(params.target_sz)/2; % size from which we extract features bg_area = round(params.target_sz + avg_dim); % pick a "safe" region smaller than bbox to avoid mislabeling fg_area = round(params.target_sz - avg_dim * params.inner_padding); % saturate to image size if(bg_area(2)>size(im,2)), bg_area(2)=size(im,2)-1; end if(bg_area(1)>size(im,1)), bg_area(1)=size(im,1)-1; end % make sure the differences are a multiple of 2 (makes things easier later in color histograms) bg_area = bg_area - mod(bg_area - params.target_sz, 2); fg_area = fg_area + mod(bg_area - fg_area, 2); % Compute the rectangle with (or close to) params.fixedArea and % same aspect ratio as the target bbox area_resize_factor = sqrt(params.fixed_area/prod(bg_area)); params.norm_bg_area = round(bg_area * area_resize_factor); % Correlation Filter (HOG) feature space % It smaller that the norm bg area if HOG cell size is > 1 params.cf_response_size = floor(params.norm_bg_area / params.hog_cell_size); % given the norm BG area, which is the corresponding target w and h? norm_target_sz_w = 0.75*params.norm_bg_area(2) - 0.25*params.norm_bg_area(1); norm_target_sz_h = 0.75*params.norm_bg_area(1) - 0.25*params.norm_bg_area(2); % norm_target_sz_w = params.target_sz(2) * params.norm_bg_area(2) / bg_area(2); % norm_target_sz_h = params.target_sz(1) * params.norm_bg_area(1) / bg_area(1); params.norm_target_sz = round([norm_target_sz_h norm_target_sz_w]); % distance (on one side) between target and bg area norm_pad = floor((params.norm_bg_area - params.norm_target_sz) / 2); radius = min(norm_pad); % norm_delta_area is the number of rectangles that are considered. % it is the "sampling space" and the dimension of the final merged resposne % it is squared to not privilege any particular direction params.norm_delta_area = (2*radius+1) * [1, 1]; % Rectangle in which the integral images are computed. % Grid of rectangles ( each of size norm_target_sz) has size norm_delta_area. params.norm_pwp_search_area = params.norm_target_sz + params.norm_delta_area - 1; end
05-31
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值