##HttpServletRequest 和 ##HttpServletResponse 基础知识

##HttpServletRequest

> 这个对象封装了客户端提交过来的一切数据。


1. 可以获取客户端请求头信息


        //得到一个枚举集合  
        Enumeration<String> headerNames = request.getHeaderNames();
        while (headerNames.hasMoreElements()) {
            String name = (String) headerNames.nextElement();
            String value = request.getHeader(name);
            System.out.println(name+"="+value);
            
        }

2. 获取客户端提交过来的数据


        String name = request.getParameter("name");
        String address = request.getParameter("address");
        System.out.println("name="+name);
        System.out.println("address="+address);

        -------------------------------------------------

        //name=zhangsan&name=lisi&name=wangwu 一个key可以对应多个值。

        Map<String, String[]> map = request.getParameterMap();
        
        Set<String> keySet = map.keySet();
        Iterator<String> iterator = keySet.iterator();
        while (iterator.hasNext()) {
            String key = (String) iterator.next();
            System.out.println("key="+key + "--的值总数有:"+map.get(key).length);
            String value = map.get(key)[0];
            String value1 = map.get(key)[1];
            String value2 = map.get(key)[2];
            
            System.out.println(key+" ======= "+ value + "=" + value1 + "="+ value2);
        }

3. 获取中文数据

> 客户端提交数据给服务器端,如果数据中带有中文的话,有可能会出现乱码情况,那么可以参照以下方法解决。

如果是GET方式
    
    1. 代码转码
            String username = request.getParameter("username");
            String password = request.getParameter("password");
            
            System.out.println("userName="+username+"==password="+password);
            
            //get请求过来的数据,在url地址栏上就已经经过编码了,所以我们取到的就是乱码,
            //tomcat收到了这批数据,getParameter 默认使用ISO-8859-1去解码
            
            //先让文字回到ISO-8859-1对应的字节数组 , 然后再按utf-8组拼字符串
            username = new String(username.getBytes("ISO-8859-1") , "UTF-8");
            System.out.println("userName="+username+"==password="+password);
        
            直接在tomcat里面做配置,以后get请求过来的数据永远都是用UTF-8编码。 
    

    2. 可以在tomcat里面做设置处理 conf/server.xml 加上URIEncoding="utf-8"
 
          <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>


如果是POST方式

        这个说的是设置请求体里面的文字编码。  get方式,用这行,有用吗? ---> 没用
        request.setCharacterEncoding("UTF-8");
    

        这行设置一定要写在getParameter之前。


##HttpServletResponse

> 负责返回数据给客户端。 

输出数据到页面上


        //以字符流的方式写数据    
        //response.getWriter().write("<h1>hello response...</h1>");
        
        //以字节流的方式写数据 
        response.getOutputStream().write("hello response2222...".getBytes());


### 响应的数据中有中文,那么有可能出现中文乱码

以字符流输出

> response.getWriter()


        //1. 指定输出到客户端的时候,这些文字使用UTF-8编码
        response.setCharacterEncoding("UTF-8");
        
        //2. 直接规定浏览器看这份数据的时候,使用什么编码来看。
        response.setHeader("Content-Type", "text/html; charset=UTF-8");
        
        response.getWriter().write("我爱黑马训练营...");



以字节流输出 

> response.getOutputStream()


    
        
        //1. 指定浏览器看这份数据使用的码表
        response.setHeader("Content-Type", "text/html;charset=UTF-8");
        
        //2. 指定输出的中文用的码表
        response.getOutputStream().write("我爱深圳黑马训练营..".getBytes("UTF-8"));


        --------------------------------------------

###不管是字节流还是字符流,直接使用一行代码就可以了。

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

    然后在写数据即可。

猜你喜欢

转载自blog.csdn.net/kikock/article/details/80642797
今日推荐