码迷,mamicode.com
首页 > Web开发 > 详细

使用JSP/Servlet技术开发新闻发布系统——第二章 JSP数据交互(一)

时间:2018-08-22 16:56:51      阅读:349      评论:0      收藏:0      [点我收藏+]

标签:send   ssi   修改   传递   技术开发   interval   实例化   odi   nal   

1、 JSP内置对象:JSP内置对象是 Web 容器创建的一组对象;

   ●JSP常用的内置对象:out、request、application、session、respons等;

  ●内置对象不需要实例化的原因:

       ★由Web容器加载的一组Servlet API的实例,这些实例由 JSP 规范进行了默认的初始化操作,可以直接在JSP中使用,特别要注意的是JSP内置对象名称均是JSP的保留字,不得当作自定义变名使用;

2、JSP的内置对象out:

  ●out 内置对象是在 JSP 开发过程中使用最为频繁的对象,out 对用于向浏览器输出数据,其常用的方法是 print( ) , 该方法用于在页面中显示字符串信息。

    例如在页面上显示 “Hello JSP‘:

             <%

                 out.print(“Hello JSP”);

             %>

3、 JSP 内置对象 request:

  request对象是最常用的 JSP 内置对象之一 , 其中包含了有关浏览器请求的信息;

    工作原理:

           技术分享图片

       ●request对象常用方法:

方法名称

 说明

String getParameter(String name)

根据页面表单组件名称获取页面提交数据

String[ ] getParameterValues(String name)

获取一组相同名称名命的表单组件提交的数据(表单组件对应多个值时的请求数据 )

void setCharacterEncoding(String charset)

指定每个请求的编码

RequestDispatcher getRequestDispatcher(String path)

返回一个javax.servlet.RequestDispatcher对象,该对象的forward( )方法用于转发请求

 

 

eg:编码实现学员的注册功能:

注册reginput . jsp页面的jsp:

<body>

         <div align="center">请输入注册信息

                  <form name="form1" method="post" action="reginfo.jsp">

              <table  border="0" align="center">

                                <tr>

                            <td>用户名:</td>

                            <td><input type="text" name="name"></td>

                              </tr>

                                   <tr>

                                  <td height="19">密码:</td>

                                  <td height="19"><input type="password" name="pwd"></td>

                                   </tr>

                                   <tr>

                            <td>信息来源:</td>

                            <td>

                                                     <input type="checkbox" name="channel" value="报刊">报刊

                                           <input type="checkbox" name="channel" value="网络">网络<br/>

                                           <input type="checkbox" name="channel" value="朋友推荐">朋友推荐

                                           <input type="checkbox" name="channel" value="电视">电视

                                      </td>

                              </tr>

                              <!-- 以下是提交、取消按钮 -->

                              <tr >

                            <td colspan="2" align="center" >

                                            <input type="submit" name="Submit" value="提交">

                                            <input type="reset" name="Reset" value="取消">

                            </td>

                              </tr>

              </table>

                </form>

         </div>

         </body>

提交reginfo . isp页面的jsp:

<body>

       <%

           request.setCharacterEncoding("UTF-8");

           String name = request.getParameter("name");

           String pwd = request.getParameter("pwd");

           String[] channels = request.getParameterValues("channel");

       %>

       <div align="center">你输入的注册信息

              <table border="0" align="center">

                  <tr>

                      <td width="80" height="20">用户名:</td>

                      <td><%=name%></td>

                  </tr>

                  <tr>

                      <td height="20">密码:</td>

                      <td><%=pwd%></td>

                  </tr>

                  <tr>

                      <td height="20">信息来源:</td>

                      <td >

                      <%

                          if (channels != null) {

                              for (String channel: channels) {

                                  out.print(channel+"&nbsp;");

                              }

                          }

                      %>

                      </td>

                  </tr>

              </table>

       </div>

       </body>

      

代码分析:

request的getParameter()方法是最为常用的,使用此方法可以获得请求中所提交的参数值,

  例如,注册页面 (reginput . jsp) 通过 HTML 表单为注册提交页面 (reginfo . isp) 提交了两个参数,名称分别为name 和 pwd,通过调用 request .getParameter( "name‘ ) 和 request.getParameter 就可以获取这两个参数的值;

★在注册页面中,出现了多个复选框 复选框的名称都是 channel, 在注册提交页面中使用getParameterValues(“channel”) 方法就可以获取一个字符串数组,该数组中存储的是所有选中的复选框对应的值。如果没有选择任何选项,请求中不包含名为channel的参数. 则该方法返回null;

★request 对象的 setCharacterEncodlrig ( ) 方法用于设置字符集,可以用来解决中文乱码问题,常用字符集编码有 ASCll 、ISO-8859-1 、GB2312、GBK、Unicode、UTF-8等,java在其内部使用 Unicode字符集来表示字符,这样就存在 Unicode 字符集和本地字符集进行换的过程,左Web 应用中, 通常都包括了浏览器、Web 服务器、Web 应用程序和数据库等部分,每一部分都有可能使用不同的字符集,从而导致字符数据在各种不同的字符集之间转换时,出现乱码的问题;

对于中文乱码问题,根据产生的原因,主要有以下几种解决方案:

▲以POST 方法提交的表单数据中有中文字符时:

  ◆Tomcat对请求数据默认采用ISO-8859-1字符集进行解码,request 对象的 getParameter方法得到的字符串是以 ISO-8859-1 转换而来的,所以在获取请求参数值之前,调用setCharacterEncoding ( "UTF-8“ )方法,将请求的解码方式设定为 UTF-8。注意:页面和浏览器发请求也应一致使用 UTF-8 编码, 通过 JSP 页面设置 page 指令的 contentType属性,指定页面内容的编码格式如下:

     <% page contentType=”text/html;charset=UTF-8”%>

      ☆注:cententType和pageEncoding的区别:cententType定义响应的资源类型,也可以包含JSP页面和响应内容的字符集;pageEncoding 指定JSP文件的字符集及默认的 contentType字符集;

以 GET方法提交的表单数据中有中文字符时:

  ◆当采用GET方式提交表单时,提交的数据作为查询字符串被附加到URL的末端发送到服务器,对于这部分数据,在服务器调用setCharacterEnCoding ( ) 方法是不起作用的,我们需要得到请求参数值后,进行编码转换,在上面的示例中,将表单的提交方式改为 method= ‘get‘,则在注册提交页reginfo中将获得用户名的代码修改:

        String name = request.getParameter("name");

    name=new String(name.getBytes(“ISO-8859-1”),”UTF-8”)

      ☆其中,nama.getBytes(“ISO-8859-1”)是按照 “ISO-8859-1”字符集编码把 name 字符串转换为btye数组,再通过new String()方法,使用指定的”UTF-8”字符集把 byte 数组构造为一个新的String;

在 Tomcat 中设置字符集:

  ◆当表单采用 GET 方法提交时,虽然可以通过构造一个新的String 的方式解决中文乱码问题,但是当获取多个参数值时.每个参数都进行重新编码,操作比较烦琐,效率也不高。这时可以通过Tomcat中设置字符集的方式解决,配置方式如下:找到 Tomcat 目录结构\conf\server . xml 文件,<Connector>元素中添加 URIEncoding 属性,将它的值设置为 “UTF-8 “;

      <Connector port="8080" protocol="HTTP/1.1"connectionTimeout="20000"redirectPort="8443" URIEncoding =“UTF-8”/>

        在 Tomcat 中设置了字符集编码,对于浏览器以 GET 方式提交的数据则无须在 JSP页面中再进行重新编码处理 (注意浏览器需以 UTF-8,编码发送 URL);

 

4、JSP内置对象response:

  与request对象相对应的是response对象,response对象用于响应客户请求并向客户端输出信息;

  ●工作原理:

           技术分享图片

  ●response对象常用的方法:

addCookie(Cookie cookie)

向客户端添加Cookie;

setContentType(String type)

设置HTTP响应的contentType类型

setCharacterEncoding(String charset)

设置响应所采用字符编码类型

sendRedirect(String location)

将请求重新定位到一个新的URL上

          最常用的方法:sendRedirect(String location):客户端将重新发送请求到指定的URL;

5、转发与重定向:

转发:从程序运行的角度理解. 即当客户端发送一个请求到服务器后, Web 服务器在容器内部完成求跳转, 然后将最终的结果发送给浏览器,整个过程都是在容器内部完成的,而对应到客户端,无论服务器内部如何处理,作为浏览器都只是提交了一个请求,因而客户端的 URL 地址不会发生改变;

转发的实现很简单,使用 request 的 getRequestDispatcher ( ) 方法得到 RequestDispatcher 对象,此对象用于封装一个由路径所标识的服务器资源,然后用这个对象调用 forward )方法,将请求传递服务器上另外的 JSP 页面或者 HTML 文件;

转发可以在多个页面交互过程中实现请求数据的共享;

重定向:当用户登录成功后. 使用的是 response 对象的 sendRedirect ( ) 方法。 那么该方法行的结果是客户端重新向服务器请求一个地址链接,由于是发送新的请求 , 因而上次请求中的数将随之丢失 这种行为称为重定向。由于服务器重新定向了URL, 因而在客户端浏览器中显示的新的 URL 地址, 所以重定向可以理解为浏览器至少提交了两次请求

●转发和重定向有什么区别:转发和重定向都能够实现页面的跳转,不同之处表现在以下几方面:

  ◆转发过程:Web 服务器内部将一个 request 请求的处理权交给另外一个资源,属于同一个访问请求和响应过程,所以 request对象的信息不会丢失,

    ★转发是在服务器端发挥作用,通过 RequestDispatcher 对象的forward( ) 方法将交信息在多个页面间进行传递;

    ★转发是在服务器内部控制权的转移 , 客户端浏览器的地址栏不会显示出转向的地址。

  ◆重定向过程:Web 服务器向浏览器返回一个响应,浏览器接受此响应后再发一个新的 http请求到服务器,这属于两次不同的请求, 则上一次请求的 request信息将丢失;

    ★重定向是在客户端发挥作用,通过请求新的地址实现页面转向。其通过浏览器重新请求地址,在地址栏中可以显示转向后的地址。

如果需要在重定向的情况下将简单数据(值类型、字符串)传递到目标页面;也以使用查询字符串(Query String)实现:

  response.sendRedirect(“welcome.jsp?username=”+name”);

  查询字符串以名值对方式 存储数据,通过“?”连接在URL的后面,多个名值对可以使用“&”进行分隔;

查询字符串的应用:

eg:选择页面

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

    <head>

        <title>选择喜欢的颜色</title>

    </head>

    <body>

         请从以下7种颜色中,选择你最喜欢的颜色<br/>

        <a href="color.jsp?color=赤色">赤色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=橙色">橙色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=黄色">黄色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=绿色">绿色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=青色">青色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=蓝色">蓝色</a>&nbsp;&nbsp;

        <a href="color.jsp?color=紫色">紫色</a>

    </body>

</html>

eg:展示页面

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

    <head>

        <title>我喜欢的颜色</title>

    </head>

    <body>

    <%  

             //已在Tomcat中设置字符集为“UTF-8”

        String color = request.getParameter("color");

    %>

        你最喜欢的颜色是:<%=color%>

    </body>

</html>

分析:通过上面的代码, 可以发现数据传递成功了:代码中的a标签部分,在跳转页面的后面都有一个 ‘?‘. 以及一个参数名 ‘color‘,每一个参数的值就是所选择的颜色。而在结果页面中使用 request 对象的 getParameter ) 方法 , 就可取到参数 ‘color" 的值,达到了数据的传递效果;

注:使用超链接进行数据传递时: 采用的是 GET 方式提交请求,如果在传递裁据中存中 文,使用 request 对象直接获取时,容易产生乱码

问題。因此,需要对数据进行重新编码。

  ▲可以使用 String 对象的方法实现数椐重新编码;

    ★语法 :new String ( 需要编码的数据.getBytes(“ ISO-8859-1“ ),“ UTF-8“ );

  ▲也可以通过设置 Tomcat 字符集实现:

    ★当传递多个数据时, 可用 “&” 连接。

      eg:<a href=“ color.jsp?color=赤色&id=1>赤色</a>, 在荻取数据时, 依然可以通过参数名 “id” 读取参数值 “1”;

 

6、JSP 内置对象 session:

  会话:

session:原义是指有始有终的一系列动作;

  eg:打电话时,甲方拿起电话拨通乙方电话这一系列的过程就可以称为一个会话,电话挂断时会话结束;

对Web开发来说,一个会话就是在一段时间内一个用户与 Web 服务器的一连串相关的交互过程,它可包含浏览器与服务器之间的多次请求,响应过程:在一次会话中,用户可能会多次请求访问一网页,也有可能请求访问同一个服务器的其他资源;

下图描述了浏览器与服务器的一个会话过程:

   技术分享图片

会话机制是一种服务器端的机制,当用户向服务器发出第一次请求时,服务器会为该用户创建唯一的会话,会话将一直延续到用户访问结束;

当服务器接收到客户端的请求时,服务器首先会判断是否已经创建了与该客户端对应的会话,如果已经创建就将该请求与此会话相关联,如果没有包建,则会创建一个新会话,此客户端之后发送的请求将关联到该会话;

而服务器判断是否创建了相关会话,是通过一个唯一的标识 sessionid来实现的。如果在客户端请求中包含了一个sessionid,则说明在此前已经为客户端创建了会话,服务器就会根据这个 sessionid将对应的会话对象读取出来;否则就会创建一个新的会话对象并生成一个 sessionid,并将 sessionid在本次晌应的过程返回客户端保存;

sessionid会返回客户端,那么在客户端 sessionid 会保存在什么位置?

  回答:在客户端保存用户信息使用的是 cookie, 因此保存 sessionid 的方式也是使cookoe来实现的,在客户端的 cookie 中,保存 sessionid 的名称是 JSESSIONID, segsionid 的值是由一串复杂字符串组成的;

    eg:JSESSIONID=2A 11D30C7B32329D7C8BF16DC598C509 , 其中等号后面的字符串就是分配的 scssionid 对应的值;

7、 session对象:

  session 对象作为JSP提供的内置对象之一 , session 对象允许用户访问会话的相关信息,以及绑定数据到话(在服务器端使用类似于哈希表的结构来保存信息)。绑定到会话的数据可以在多次请求之间持有效;

    ◆ session对象的常用方法:

方法名称

说明

String getId()

获取sessionid

void setMaxInactiveInterval(int interval)

设定session的非活动时间

int getMaxInactiveInterval()

获取session的有效非活动时间(以秒为单位)

void invalidate()

设置session对象失效

void setAttribute(String key, Object value)

以key/value的形式将对象保存对到session

Object getAttribute(String key)

通过key获取session中保存的对象值

void removeAttribute(String key)

从session中删除指定名称(key)所对应的对象

     ●session与窗口的关系:

        ◆每个session对象都与一个浏览器窗口对应 ,重新开启一个浏览器窗口,可以重新创建一个session对象(不同版本浏览器可能有所差别)

        ◆通过超链接打开的新窗口,新窗口的session与其父窗口的session相同

8、使用 session 对象实现权限控制:

    eg:用户通过登录页面登网站, 如果该用户是已注册用户 . 系统会保存该用户的登录信息. 并让用户进入其欲访问的页面;

       用户直接访问网站的某个页面. 系统会查询是否保存有该用户的登录信息,如果有则显示该页面的内容;如果没有,则转入登录页面. 要求用户登录网站

  这里要实现的权限访问控制是基于 session 对象来完成的。

    eg使用 session 为新闻发布系增加访问控制,要求新闻发布系统中所有针对新闻的操作,如发布新闻、 修改新闻 、发布新闻标题、 修改新闻标题,都只能由管理员才能完成。普通用户没有权限进行访问,访问控制流程如图:

                技术分享图片

    ★根据新闻发布系统的访问控制流程,实现访问控制的流程如下:

1、在登陆页面输入用户名和密码;

2、在登陆处理页面进行登陆验证;

3、在会话中,保存用户信息,如果用户登录成功,则跳转到管理员页面;

4、在管理员页面读取会话中的用户信息,并进行校验;

5、验证失败,返回登陆页面;

eg:登陆处理页面jsp的代码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>登录处理页面</title>

</head>

<body>

    <%

        request.setCharacterEncoding("UTF-8");

        //获取请求数据,并去除空格

        String name = request.getParameter("userName").trim();

        String pwd = request.getParameter("pwd").trim();

        boolean valid = false;  //判断用户验证是否成功

        if("admin".equals(name)&&"admin".equals(pwd)){

             valid = true;

             //设置用户登录信息

             session.setAttribute("login", name);

             //设置session过期时间

             session.setMaxInactiveInterval(10*60);

        }

        if (valid) {

            request.getRequestDispatcher("admin.jsp")

                .forward(request,response);

        } else {

                response.sendRedirect("index.jsp");

        }

    %>

    </body>

</html>

分析:接下来在管理员操作页面加入登录验证。此时要完成的任务是,从 session 中提取用户的信息,如果用户信息存在,则可以进行操作; 如果用户信息不存在 . 则跳转到登录页面。这一步实现了问的控制;

eg:在管理员界面加入如下代码:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

  <head>  

    <title>管理员</title>

  </head>

 

  <body>

    <%

           String login = (String) session.getAttribute("login");

           if (login == null){

               response.sendRedirect("index.jsp");

               return;

           }

    %>

    您好,欢迎您!

  </body>

</html>

 

分析:在登录处理页面中,已经实现了对用户的身份验证,为什么在此处还要再进验证。原因很简单.,如果用户不通过登录方式,而是直接在浏览器地址栏中输入管理员页面的地址这样将会直接绕过登录限制而访问成功。 所以需要在管理员操作界面再添加控制语句,以避免此情况的发生。

◆至此:此示例的访问控制已经基本实现了;

  ▲验证访问控制效果的具体步骤如下:

    1、直接在浏览器地址栏中输入URL,访问管理员操作页面;

    2、通过登录页面进入管理员操作页面;

    3、重新开启一个浏览器窗口,直接访问管理员操作页面;

◆按照以上步骤运行,观察每个步骤会发生什么样的结果 , 并思考为什么会产生这样的结果。下面对此进行分析:

  ☉如釆直接在浏览器地址栏中输入管理员操作页面的 URL, 系统会跳入登录页面 , 提示用户进行登录。 这个原因很简单,因为我们在管理员操作页面中加入了访问控制,只有正确登陆后,进入管理员操作界面,会话中才会存储用户登录成功的状态信息,才可以正常访问管理员操作页面;

  ☉如果重新开启一个浏览器窗口,直接访问管理员操作页面,不管在其他窗口中是否登陆,所进入的肯定是登录页面,这是我们经常遇到的问题,即 session 与浏器窗口的关系 ;

  ☉每个 session 对象都与浏览器一一对应,也就是说,重新开启一个浏览器窗口,相当于新创建一个 scssion 对象。但是需要注意的是,由于浏览器或版本不同,即使重新开启个浏览器窗口,也会认为是同一个 session 对象,也就是所谓的出现会话共享问题;

    ☆以 IE8为例,可以在浏览器上执行 "文件” — "新建会话’ 命令新建一个会话窗口。

    ☆另外,提供两种取消浏览器窗口共享 session 的办法:

        1、修改 IE8 的快捷方式:右击 IE8快捷方式图标,在弹出 的快捷菜单中选择 ’属性" —“ 目 标’ 选项, 末尾添加 “- nomerge",修改后如"C:\Program Files\Itemet Explorer\iexplorc.exe" -nomerge;

        2、使用命令参数 "iexpldre.exe -nomerge‘ 打开IE

  ☉现在就可解释为什么在登录成功后,重新开启一个浏览器窗口直接访问管理员操作页即可进入登录页面了,在其他浏览器窗口中保存的登录信息与新的浏览器窗口完全无关,所以系统会判定尚未登录,跳转进入登录页面;

9、会话的失效:

会话也是有时效的,使会话失效的方式有两种: 一种是会话超时;另一种是手动调用方法设置失效;

●会话超时是指两次请求的时间间隔超过了服务器允许的最大时间间隔;

 会话的超时间隔可通过三种方法设置:

  ◆通过 session 对象的setMaxInactiveInterval( )方法设置,单位是秒;

        <%

      session.setAttribute("login","admin");

      //参数 600 的单位是秒, 表示在 10 分钟后 session对象失效;

      session.setMaxInactiveInterval(600);

      response.sendRedirect("admin.jsp");

     %>

  ◆在项目的web.xml中设置,单位是分钟,设置为0或负数,表示永不超时;

        <session-config>

            <session-timeout>10</session-timeout>

     </session-config>

  ◆在应用服务器中设置,在 Tomcat目录下的/conf/web.xml文件中找到<sesston-config>元素, 其中<sesston-config>元素中的 30 就是默认的时间,单位是分钟,可以修改其值;

  ☉动调用方法设置失效是通过调用 session 对象的 invalidate()方法实现的, 主要应用于用户注销的场合,但如果只想清空会话中绑定的某个数据对象,则可以调用 session . removeAttribute (String key)方法,将指定的对象从会话中清除,而会话仍然有效;

10、    include指令:

  ●文件引用指令include,将一些可以重用的内客写入一个单独的文件,然后通过 include 指令引用该文件 , 从而缓解代码的冗余问題, 并且修改时也更方便;

  include 指令的基本语法:以<%@ 开始,以 %> 结束。

          语法:<%@  include file="应用文件路径 " %>

   Include 指令表示,在 JSP 编译时插入一个包含文本或代码的文件,这个包含的过程是静态的,包含的文件可以是 JSP 页面、HTML 网页、文本文件等。

  include 指令只有一个 fi1e 属性 , 表示被包含的文件路径;

 

使用JSP/Servlet技术开发新闻发布系统——第二章 JSP数据交互(一)

标签:send   ssi   修改   传递   技术开发   interval   实例化   odi   nal   

原文地址:https://www.cnblogs.com/HQING/p/9517891.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!