Java学习笔记——request&response

一、Request:
     1、获得客户机信息
          getMethod(); 获得请求方式
          getQueryString(); 获得请求路径后的参数
          getRemoteAddr(); 获得客户机的IP地址
          getRequestURI(); 获得请求的路径(不带盘符)
          getRequestURL(); 获得请求的路径(带盘符)
          getContextPath(); 获得工程名
     2、获得请求参数
          String getParamter(String name)获得一个参数的值
          String[] getParamterValues(String) 获得一个参数的多个值:复选框checkbox
          Map getParamterMap(); 获得所有参数的键值对集合
     3、获得请求头
          String getHeader(String name); 获得一个头信息
          int getIntHeader(String name);
          Date getDateHeader(String name);
          getHeaderNames();获得所有头的名字
          getHeaderVaules(String name); 获得一个头的所有值
     4、作为域对象存取值
          setAttribute()
          getAttribute()
          removeAttribute() 
二、Response:
     1、响应行:状态码
          setStatus(int i); 设置状态码     
     2、响应头:
          setHeader(String name,Object value)
          addHeader(String name,Object value)
     3、响应体
          (1)字节流
               response.getOutputStream();
          (2)字符流
               response.getWriter().write();写出的内容不是字符串形式
               response.getWriter().println();写出的内容是字符串形式
     4、下载的方式
          (1)标签链接下载
                    这种下载方式浏览器会将其能够识别的文件类型直接展示在浏览器上,而不会提示下载信息
          (2)设置两个头一个流
               response.setContentType("文件的类型");// MIME类型
               response.setHeader("content-disposition","attchment;filename='要下载的文件名'");
                    这种下载方式会将任意的文件类型以下载的方式响应给浏览器
               文件输入流InputStream is = new FileInputStream("本地文件路径")
               响应的输出流OutputStream os = response.getOutputStream();
               两个流进行对接。
三、中文乱码问题:
     1、Response:
          (1)字节流
               //设置浏览器默认的打开编码方式
               response.setHeader("content-type","text/html;charset=UTF-8")
               //中文转成字节数组编码
               response.getOutputStream().write("再续啸傲".getBytes("UTF-8"));
          (2)字符流     
               //设置缓冲区的编码
               response.setCharacterEncoding("UTF-8")
               //设置浏览器默认的发开方式
               response.setHeader("content-type","text/html;charset=UTF-8")
               //这两句话可以用一句代码实现
               response.setContentType("text/html;charset=UTF-8")
          (3)下载时的中文文件名乱码
           String agent = request.getHeader("User-Agent");
           if(agent.contains("Firefox")){
            // 火狐浏览器
              filename = base64EncodeFileName(filename);
        }else{
            // IE,其他浏览器
            filename = URLEncoder.encode(filename, "UTF-8");
        }

     public static String base64EncodeFileName(String fileName) {
        BASE64Encoder base64Encoder = new BASE64Encoder();
        try {
            return "=?UTF-8?B?"
                    + new String(base64Encoder.encode(fileName
                            .getBytes("UTF-8"))) + "?=";
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
            throw new RuntimeException(e);
        }
         }
     2、Request:
          (1)post请求方式
               request对象有缓冲区,缓冲区中默认的编码方式为ISO-8859-1
               //设置request缓冲区的编码
               request.setCharacterEncoding("UTF-8");
          (2)GET请求方式
               由于GET请求会将请求参数显示在地址栏中,浏览器会对参数进行编码。所以需要将编码内容取出来后再进行编码
               处理方式
                    i.修改浏览器提交的编码
                    ii.使用URLEncoder和URLDecoder类对中文进行编码和解码
                    iii.使用String类的构造方法
                         new String(username.getBytes("ISO-8859-1"),"UTF-8")
四、转发与重定向的区别
          转发:request.getRequestDispatcher(String path).forward(request,response)
          重定向:response.sendRedirect(String)
          (1)转发的地址栏无变化,重定向的地址栏有变化
          (2)转发是一次请求一次响应,重定向是两次请求两次响应
          (3)request域对象中存储的值在转发中是有效的,在重定向中是无效的
          (4)转发的路径不需要加工程名,重定向的路径需要加工程名

你可能感兴趣的:(java,基础笔记,学习笔记)