JSP学习之请求和响应编码

  今天的学习涉及到了 jsp中的两大函数 request(请求) 和 response(响应),这应该是大家学习jsp时最先碰到的两个对象,具体有什么作用呢?应该怎么用呢?请继续往下面看.

 

一.request介绍

  (1) request对象 是 javax.serlvet.httpServletRequest类型的对象 .是一个域对象, 该对象代表了客户端的请求信息 , 主要用于接受通过HTTP协议传送到服务器的数据.(包括头信息 , 系统信息 , 请求方式以及请求参数) , request对象的作用域是一次请求

 

二.request的请求编码

  (1) 涉及到服务端和客户端还有浏览器之间的传值与显示问题,那么不可避免的我们需要聊到编码问题,也就是解码或者转码 , 在我们使用的Tomcat中 , 它的默认编码是 <iso-8859-1> ,而众所周知的我们的中文编码用的比较多的是<UTF-8>,那么我们在通过request传值的时候就必须要考虑到解码的问题 , 否则迎接我们的就是那些花里胡哨的乱码 . 这个转码怎么转呢 ?

    就拿我们的请求参数的传值来说 , 我们通过<form>表单的的name属性来设置取值 , 其中还要通过 它method中的’get’和’post’两种传值方式来进行不同的解码,我们先说post

   下面是一个Servlet类中的doPost方法

   public void doPost(HttpServletRequest req, HttpServletResponse reps) throws ServletException, IOException

   {

      req.setCharacterEncoding(“UTF-8”); //设置请求编码为 UTF_8

      ……. 

   }

     这个 setCharachterEncoding()方法就是 [post]传值方式的解码方式 , 作用就是让服务器把它那个 <iso-8859-1>的编码按照我我们需要的<UTF-8>的编码 解码后再给放到我们手上,这也是说为什么我们说这个 req.setCharacterEncoding(“UTF-8”)  是请求编码 ,这是我们给服务器发送请求 ,服务器按照我们的请求编码回应我们.

   

  我们再看 get传值方式

  下面是一个Servlet类中的doGet方法

  public void doGet(HttpServletRequest req, HttpServletResponse reps)
            throws ServletException, IOException
    {
         //假设jsp页面有一个 name名为 ‘Sex’的值传过来 ,我们先接收 并且转码

    String SexStr = req.getParameter(“Sex”);

    String Sex = new String(SexStr.getBytes(“iso-8859-1”), “UTF-8”);
    }

   这是什么意思呢 , 这个是我们先通过服务器的 <iso-8859-1>的方法获得Sex的底层字节数组 ,我们那用”UTF-8″的方式对字节数组进行加密,得到的就是我们要的中文字符了. 至于为什么 get和post两个解码方式不一样,我们可以通过测试看看地址栏就大概想到了,这个我就不细说了……..

  说完 request这个请求编码问题,我们再来看看 response响应编码

 

三 , response介绍

  response 对象用于响应客户请求,向客户端输出信息。它封装了JSP产生的响应,并发送到客户端以响应客户端的请求。请求的数据可以是各种数据类型,甚至是文件。response对象在JSP页面有效。

 

四, response 响应编码

  还是上代码

  public void doPost(HttpServletRequest req, HttpServletResponse reps) throws ServletException, IOException

  {

 

    reps.setContentType(“text/html; charset=UTF-8”);

 

    ……. 

 

  }

 

   以上代码还是一个Servlet类的的doPost方法 ,它的作用更直接 ,就拿表单里的下拉框来说我们可以给下拉框一个默认选中的选项 , 它的重要有点类似 ,就是给服务器和网页定了一个标准, 我给你的数据  还有你在网页上首先默认加载的数据必须是 <UTF-8>的编码格式 , 这个是它一个主要作用 ,大家不知道会不会经历过 ,有时候自己写的网页测试时候 ,加载出来 , 所有的中文变为了韩文亦或者问号 , 这样的情况对我们开发人员来说很简单,在浏览器中

  

 

 有一个文字编码,我们在这里设置一下就可以了,不过如果对于一些小白的客户来说,我来逛你网站我只想买东西 , 你一出来就给我一个群看不懂的东西, 那么这个人的第一个感觉就是很差,  用户体验很差 , 所以 , 这个对浏览器的默认显示文字编码进行代码设置 还是很有必要的,因为我们这一行 用户体验是很重要的一个东西 .

   在说完请求和响应编码的设置时候,再来补充一下细节,这两个语句必须放在你使用的方法的最上面,不管你是现在 doGet 还是 doPost中 , 它都要在最上面 ,上代码示例   
      public void doGet(HttpServletRequest req, HttpServletResponse reps)
            throws ServletException, IOException
      {
            doPost(req, reps);
      }
      public void doPost(HttpServletRequest req, HttpServletResponse reps)
              throws ServletException, IOException
      {

      //设置请求响应编码
            req.setCharacterEncoding(“UTF-8”);
            reps.setContentType(“text/html; charset=UTF-8”);

   }

 

 

 

 

  

   

版权声明:本文为JP0822原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/JP0822/p/12956148.html