JavaWeb编程技术(沈泽刚版)教材习题参考答案

上传人:wuli****0220 文档编号:146683670 上传时间:2022-08-31 格式:DOC 页数:20 大小:156KB
返回 下载 相关 举报
JavaWeb编程技术(沈泽刚版)教材习题参考答案_第1页
第1页 / 共20页
JavaWeb编程技术(沈泽刚版)教材习题参考答案_第2页
第2页 / 共20页
JavaWeb编程技术(沈泽刚版)教材习题参考答案_第3页
第3页 / 共20页
点击查看更多>>
资源描述
Java Web编程习题解析4.1 第1章习题解析1. 略。2. 答:URL称为统一资源定位符, URL通常由4部分组成:协议名称、页面所在主机的DNS名、可选的端口号和资源的名称。URI称为统一资源标识符,是以特定语法标识一个资源的字符串。URI由模式和模式特有的部分组成,它们之间用冒号隔开,一般格式如下:schema:schema-specific-part URI是URL和URN的超集。3. 答:是URL,和都是URI,是URN4. 答:动态Web文档技术包括服务器端动态文档技术和客户端动态文档技术,前者包括CGI技术、服务器扩展技术和HTML页面中嵌入脚本技术。其中HTML页面中嵌入脚本技术包括ASP、PHP和JSP技术。最流行的客户端动态文档技术是在HTML页面中嵌入JavaScript脚本代码。使用JavaScript可以设计交互式页面。与服务器端动态文档不同,JavaScript脚本是在客户端执行的。5. 答:Servlet是用Servlet API开发的Java程序,它运行在Servlet容器中。Servlet容器是运行Servlet的软件,主要用来扩展Web服务器的功能。6. 答:开发Servlet的一般步骤包括:(1)编写Servlet源程序;(2)编译;(3)将Servlet部署到Servlet容器中;(4)访问执行Servlet。7. 答:libservlet-api.jar文件。8. 答:部署描述文件名是web.xml,它是XML文件,应该存放在Web应用程序的WEB-INF目录中。9. 答:当服务器找不到用户请求的资源时将发生404错误。10. 答:JSP页面是嵌入了Java脚本元素的HTML页面。11. 答:Servlet主要用来实现业务逻辑和控制逻辑,JSP页面主要用来实现表示逻辑。4.2 第2章习题解析1. 答:Servlet接口定义了下面5个方法:public void init(ServletConfig config) public void service(ServletRequest request, ServletResponse response) throws ServletException, IOException public void destroy() public ServletConfig getServletConfig() public String getServletInfo()2. 答:Servlet是在容器中运行的组件,有一个从创建到销毁的过程,其中包括加载和实例化、初始化、提供服务以及销毁几个阶段。其中生命周期方法有init()、service()和destroy()等3个。3. 答:发生下列事件,浏览器向服务器发出请求。(1)用户点击了HTML页面中的超链接;(2)用户在HTML页面中填写一个表单并点击提交按钮;(3)用户在浏览器的地址栏中输入URL并按回车键。4. 答:查询串5. 答:HTTP请求结构由请求行、请求头、空行和请求数据组成。请求行由方法名、请求资源的URI和使用的HTTP版本3部分组成。6. 答:HTTP响应结构由状态行、响应头和响应数据3部分组成。状态行由HTTP版本、状态码和简短描述3部分组成。7. 答:GET请求主要用来从服务器检索资源,POST请求主要用来向服务器发送数据。它们的详细比较请参阅教材的表2.8。8. 答:在ServletRequet接口中定义了setAttribute()、getAttribute()、getAttributeNames()和removeAttribute()方法来处理请求作用域的属性。9. 答:forward()方法转发请求是服务器端控制权的转向,客户端地址栏中不显示转发后的资源地址。sendRedirect()方法是服务器向浏览器发送302状态码,它使浏览器连接到新的位置,浏览器地址栏可看到地址的变化。使用重定向,资源不能位于WEB-INF目录中。10. 答:可先通过请求对象的getParameterNames()方法得到Enumeration对象,然后在其上得到每个请求参数名,再通过getParameter()得到请求参数值。11. 答:A 12. 答:B 13. 答:E14. 答: action=courseServlet.do HttpServlet courseServlet15. 答: E D C B A 4.3 第3章习题解析1. 答:Web应用程序是运行在应用服务器之中的。应用服务器为Web应用程序提供一种简单的和可管理的对系统资源的访问机制。2. 答:web.xml bankappWEB-INF3. 答:D 4. 答:A 5. 答:D6. 答:F 7. 答:E 8. 答:D9. 答:getServletConfig().getServletContext()或getServletContext()10. 答:B 11. 答:B 12. 答:D13. 答:因为Applet只能运行在客户端,所以可以将它放在Web应用程序的文档根目录的任何位置,但不能将其放在WEB-INF目录或其子目录中。14. 答:不能这样做,至少不能直接这样。部署描述文件不允许为一个名称指定多个参数,所以必须像下面这样:countriesAustralia,Brazil,India,UK,US 然后在Servlet中解析param-value串的值并解释字符串中列出的多个值。15. 答:package com.demo;import javax.servlet.*;import javax.servlet.http.*;import java.io.*;public class HelloCounterServlet extends HttpServlet private Integer visits = 0; public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException response.setContentType(text/html;charset=gb2312); PrintWriter out = response.getWriter(); visits = visits +1; try Thread.sleep(2000); catch(InterruptedException e) log(Exception during sleeping.); out.println(); out.println(欢迎您! + 该Servlet已被访问 + visits + 次。); out.println(); 修改后的Servlet如下:package com.demo;import javax.servlet.*;import javax.servlet.http.*;import java.io.*;public class HelloCounterServlet extends HttpServlet private Integer visits = 0; private String dbPath = null; public void init() trydbPath = getServletContext().getRealPath(/WEB-INF/counter.db);FileInputStream fis = new FileInputStream(dbPath);DataInputStream dis = new DataInputStream(fis);visits = dis.readInt();dis.close();catch(Exception e)log(Error loading persistent counter, e); public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException,ServletException response.setContentType(text/html;charset=gb2312); PrintWriter out = response.getWriter(); synchronized(this) visits = visits +1; out.println(); out.println(欢迎您! +该Servlet已被访问 + visits + 次。); out.println(); public void destroy()tryFileOutputStream fos = new FileOutputStream(dbPath);DataOutputStream dos = new DataOutputStream(fos);dos.writeInt(visits);dos.close();catch(Exception e)log(Error storing persistent counter, e);4.4 第4章习题解析1. 答:使用请求对象(即HttpServletRequest接口)的getSession()方法。2. 答:如果客户在指定时间内没有访问服务器,则该会话超时。对超时的会话对象,服务器使其失效。通过会话对象的setMaxInactiveInterval()方法设置会话最大超时时间。web.xml文件使用元素的子元素设置最大超时时间,如下所示。20这里的最大超时时间是对整个应用程序的所有会话有效,元素指定的时间单位是分钟。setMaxInactiveInterval()方法参数单位是秒。3. 答:有些客户浏览器可能不支持Cookie或用户阻止所有的Cookie,此时不能用Cookie实现会话。4. 答:使用响应对象(即HttpServletResponse接口)的encodeURL()方法或encodeRedirectURL()方法。5. 答:不能。因为许多用户是通过代理服务器访问Internet的,此时服务器得到的是代理服务器的IP地址而不是实际用户的IP地址,因此这些用户的IP地址不唯一。6. 答:D 7. 答:A, B 8. 答:A, D9. 答:C 10. 答:A,C 11. 答:C12. 答:C, D 13. 答:B,C 14. 答:C15. 答:B 16. 答:A 17. 答:C18. 答:A,B,D,F 19. 答:具有很大的影响。该应用程序将不能维护用户的状态。Servlet容器将为每个客户的每次请求都创建一个新的会话。修改这个问题的唯一方法是修改Servlet代码加入URL重写功能。4.5 第5章习题解析1. 答:包含JSP指令、JSP小脚本和JSP表达式。2. 答:合法的JSP表达式:不合法的JSP表达式:3. 答:C4. 答:正确声明应为:5. 答:B是合法的。解析:JSP表达式中百分号和等号之间不能有空格。6. 答:D。解析:A中import的属性值中应该有等号。B的import属性值应该在一个字符串中指定。C,属性之间不允许有逗号。E,bgcolor不是合法的属性名。F,true不是buffer属性合法值。G,指令名、属性名和值都是大小写敏感的,Page应为page。7. 答:B,CA.非法:等号表明它是表达式,但表达式不能以分号结束,产生的Servlet代码将发生语法错误。out.print(myObj.m1(););B.合法:将被转换成:out.print(x=y); / y的值5赋给x并将其打印输出C. 合法:这是合法的小脚本,因为在方法调用语句的后面有分号。即使该方法返回一个值,它也是合法的,因为返回的值将被忽略。8. 答:不能在小脚本中定义方法。上面代码一旦被转换成Servlet,_jspService()方法就会像下面这样:public void _jspService(.)/ 其他代码int x = 0;int incr() return +x; out.write(The value of x is );out.print(incr();由于incr()方法定义在_jspService()方法内,所以代码不能编译。9. 答:The value of i is 3注意:如果代码写成下面形式:% for(i = 0; iThe value of i is 输出结果将为:The value of i is The value of i is The value of i is 310. 答:不能在japInit()方法中使用application对象。11. 答:The sum of x and y is 9变量x将被声明两次:一次是作为类的全局变量,因为使用了语句,另一次是在_jspService()方法中声明的局部变量,因为使用的代码是。12. 答:B 13. 答:C,E14. 答:15. 答:out.write(rn);int count = 0 ;out.write( The page count is now:rn);out.print( +count );out.write(rn);16. 答:Page改为page / 声明缺少分号 / 去掉分号 17. 答:D18. 答: 小脚本 声明 指令 动作 表达式 email:$applicationScope.mail EL表达式19. 答:A,B,C,E 20. 答:A,B,C,D21. 答:D 22. 答:C23. 答: request ()response ()out ()session ()application ()config ()exception ( )pageContext ()page ()24. 答:共有4个作用域对象:application、session、request和pageContext。用setAttribute()方法和getAttribute()方法在这些对象上设置和获得属性。在application作用域上的对象可以被Servlet容器的所有的Web应用程序访问。25. 答:可以使用pageContext的findAttribute()方法,该方法将依次在页面作用域、请求作用域、会话作用域和应用作用域中查找指定名称的属性。4.6 第6章习题解析1. 答:B 2. 答:3. 答:这两种表示等价,但第一种表示使用了JSP脚本元素,第二种表示使用的是动作。它们的功能类似,但有一点细微的差别。pageContext.include()方法在包含其他组件之前总是刷新当前页面的输出,而只有在flush属性值明确设置为true时才刷新当前页面的输出,如下所示: 4. 答:请求对象的getParameter()方法的返回值类型是String,因此display.jsp中的Integer应改为String。使用和request.getParameter()机制只能传递和检索String类型的参数。要传递其他对象类型的参数,必须在包含页面中使用request.setAttribute(),在被包含页面中使用request.getAttribute()。5. 答:D 6. 答:C 7. 答:B8. 答:可以。页面customerDisplay.jsp文件可以使用输出bean的属性值,只要它也包含一个与customerInput.jsp相同的声明并且该声明出现在声明前面即可。9. 答:10. 答:不能在同一个声明中同时使用beanName和class属性。11. 答:必须使用property指定bean的属性。param用来指定请求参数,并且不能在同一个动作中同时指定param和value属性。12. 答:使用代码段1是只有在指定作用域中找不到customer的bean对象时才执行标签体,使用代码段2在任何时候都执行属性设置标签。13. 答:可以在一个动作中设置bean的全部属性:但不能在一个动作中获得全部属性值。14. 答:C15. 答:MVC模式称为模型-视图-控制器模式。该模式将Web应用的组件分为模型、视图和控制器,每种组件完成各自的任务。该模型将业务逻辑和数据访问从表示层分离出来。实现MVC模式的一般步骤:(1)定义JavaBeans表示数据;(2)使用Servlet处理请求;(3)填写JavaBeans对象数据;(4)将结果存储在作用域对象中;(5)将请求转发到JSP页面;(6)最后在JSP页面中从JavaBeans中取出数据。4.7 第7章习题解析1. 答:两层模型即客户机/服务器模型,在两层模型中应用程序直接通过JDBC驱动程序访问数据库。三层模型是浏览器/应用服务器/数据库服务器结构,在该结构中浏览器向应用服务器发出请求,应用服务器通过JDBC驱动程序访问数据库。2. 答:传统的数据库连接的一般步骤是:(1)加载JDBC驱动程序。(2)建立连接对象。(3)创建语句对象,语句对象有3种:Statement、PreparedStatement和CallableStatement。(4)执行SQL语句得到结果集对象,调用ResultSet的有关方法就可以完成对数据库的操作。(5)关闭建立的各种对象。缺点是每次访问数据库都要建立连接对象,请求结束需关闭连接对象。这将耗费大量的时间,可能导致增大请求的响应时间。3. 答:连接Oracle数据库代码如下。Class.forName(oracle.jdbc.driver.OracleDriver); String dburl = jdbc:oracle:thin:127.0.0.1:1521:ORCL;Connection conn = Drivermanager.getConnection(dburl, scott, tiger);上述代码中,oracle.jdbc.driver.OracleDriver为JDBC驱动程序名,jdbc:oracle:thin: 127.0.0.1:1521:ORCL为JDBC URL。4. 答:使用数据源是目前Web应用开发中建立数据库连接的首选方法。这种方法是事先建立如干连接对象,存放在连接池中。当应用程序需要一个连接对象时就从连接池中取出一个,使用完后再放回连接池。这样就可避免每次请求都创建连接对象,从而降低请求的响应时间,提高效率。使用数据源建立连接是通过JNDI技术实现的。这需要首先配置数据源(可以是局部数据源或全局数据源),然后在应用程序中通过Context对象查找数据源对象。假设已经配置了名为sampleDS的数据源,建立连接代码如下:Context context = new InitialContext();DataSource dataSource = context.lookup(java:comp/env/jdbc/sampleDS);Connection dbConnection = dataSource.getConnection();5. 答:可滚动的ResultSet是指在结果集对象上不但可以向前访问结果集中的记录,还可以向后访问结果集中的记录。可更新的ResultSet是指不但可以访问结果集中的记录,还可以通过结果集对象更新数据库。要创建可滚动、可更新的ResultSet对象,必须使用Connection对象的带两个参数的createStatement()方法创建的Statement,第一个参数用下面两个常量之一: ResultSet.TYPE_SCROLL_SENSITIVE ResultSet.TYPE_SCROLL_INSENSITIVE 第二个参数使用下面常量: ResultSet.CONCUR_UPDATABLE6. 参考程序如下:package com.control;import java.io.*;import java.sql.*;import javax.servlet.*;import javax.servlet.http.*;public class BookQueryServlet extends HttpServlet Connection dbconn; public void init() String driver = org.postgresql.Driver; String dburl = jdbc:postgresql:/127.0.0.1:5432/bookstore; String username = bookstore; String password = bookstore; try Class.forName(driver); dbconn = DriverManager.getConnection( dburl,username,password); catch(ClassNotFoundException e1) catch(SQLException e2) public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException,IOException response.setContentType(text/html;charset=gb2312); PrintWriter out = response.getWriter(); out.println(); out.println(); try String sql=SELECT * FROM books; Statement stmt = dbconn.createStatement(); ResultSet rst = stmt.executeQuery(sql); while(rst.next() out.println(+rst.getString(1)+); out.println(+rst.getString(2)+); out.println(+rst.getString(3)+); out.println(+rst.getString(4)+); out.println(+rst.getDouble(5)+); catch(SQLException e) e.printStackTrace(); out.println(); out.println(); public void destroy() try dbconn.close(); catch(Exception e) e.printStackTrace(); 7. JSP页面如下: % String driver = org.postgresql.Driver; String dburl = jdbc:postgresql:/127.0.0.1:5432/bookstore; String username = bookstore; String password = bookstore; try Class.forName(driver); Connection dbconn = DriverManager.getConnection( dburl,username,password); DatabaseMetaData dbmd = dbconn.getMetaData(); out.println(数据库名:+dbmd.getDatabaseProductName()+); out.println(数据库版本:+dbmd.getDatabaseProductVersion()+); out.println(连接的用户:+dbmd.getUserName()+); out.println(数据库URL:+dbmd.getURL()+); out.println(驱动程序名:+dbmd.getDriverName()+); out.println(驱动程序版本:+dbmd.getDriverVersion()+); catch(ClassNotFoundException e1) out.println(e1); catch(SQLException e2) out.println(e2); %8. JSP页面如下: % String driver = org.postgresql.Driver; String dburl = jdbc:postgresql:/127.0.0.1:5432/bookstore; String username = bookstore; String password = bookstore; try Class.forName(driver); Connection dbconn = DriverManager.getConnection( dburl,username,password); String sql=SELECT * FROM public.books; Statement stmt = dbconn.createStatement(); ResultSet rst = stmt.executeQuery(sql); ResultSetMetaData rstmd = rst.getMetaData(); out.println(结果集列数:+rstmd.getColumnCount()+); out.println(第3列标题:+rstmd.getColumnLabel(3)+); out.println(第3列名:+rstmd.getColumnName(3)+); out.println(第3列类型:+rstmd.getColumnType(3)+); out.println(第3列类型名:+rstmd.getColumnTypeName(3)+); catch(ClassNotFoundException e1) out.println(e1); catch(SQLException e2) out.println(e2); %9. 按教材节建立局部或全局数据源sampleDS。创建程序7.9的CustomerBean.java程序和程序7.10的SampleDAO.java程序。SelectCustomerServlet.java代码如下:package com.control;import java.io.*;import java.sql.*;import java.util.*;import javax.servlet.*;import javax.servlet.http.*;import com.model.CustomerBean;import com.model.SampleDAO;public class SelectCustomerServlet extends HttpServlet public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException,IOException SampleDAO dao = new SampleDAO(); ArrayList custs = dao.selectCustomer(); request.setAttribute(custs, custs); RequestDispatcher view = getServletContext().getRequestDispatcher(/displayCustomer.jsp); view.forward (request,response); displayCustomer.jsp页面代码如下: Display Customer% ArrayList custs = (ArrayList)request.getAttribute(custs); for(CustomerBean cb : custs) out.println(cb.getCustName() + + cb.getEmail() + + cb.getPhone() + ); %10. 首先在SampleDAO类中定义下面两个字符串常量:private static final String DELETE_SQL = DELETE FROM customer WHERE custName = ?;private static final String UPDATE_SQL = UPDATE customer SET email=? , phone=? WHERE custName=?;下面是删除客户和修改客户的方法:/ 按姓名删除客户记录public boolean deleteCustomer(String custName) Connection conn = null; PreparedStatement pstmt = null; ResultSet rst = null; CustomerBean customer =null; try conn = dataSource.getConnection(); pstmt = conn.prepareStatement(DELETE_SQL); pstmt.setString(1,custName); int n = pstmt.executeUpdate(); if(n =1) return true; else return false; catch(SQLException se) return false; finally try pstmt.close(); conn.close(); catch(SQLException se) / 修改客户记录 public boolean updateCustomer(CustomerBean customer) Connection conn = null; PreparedStatement pstmt = null; try conn = dataSource.getConnection(); pstmt = conn.prepareStatement(UPDATE_SQL); pstmt.setString(1,customer.getEmail(); pstmt.setString(2,customer.getPhone(); pstmt.setString(3,customer.getCustName(); int n = pstmt.executeUpdate(); if(n =1) return true; else return false; catch(SQLException se) return false; finally try pstmt.close(); conn.close(); catch(SQLException se) 11. 首先在PostgreSQL数据库中创建一个求整数阶乘的函数my_factorial(),代码如下:CREATE OR REPLACE FUNCTION my_factorial(value integer) RETURNS integer AS $DECLARE arg integer;BEGIN arg := value; IF arg IS NULL OR arg 0 THEN RAISE NOTICE Invalid Number; RETURN NULL; ELSE IF arg = 1 THEN RETURN 1; ELSE DECLARE next_value integer; BEGIN next_value := my_factorial(arg - 1) * arg; - 函数递归调用 RETURN next_value; END; END IF; END IF;END;$ LANGUAGE plpgsql;创建JSP页面compute.jsp,连接数据库,调用存储过程: 请输入一个整数: 的阶乘为:该页面的运行结果如下:12. 略。4.8 第8章习题解析1. 答:表达式语言是JSP页面中使用的一种简洁的数据访问语言。它定义了运算符实现算术、关系等运算;可以对作用域变量、JavaBeans对象、集合的元素、请求参数、Cookie等进行简单的访问;还可以访问Java语言定义的函数(静态方法)。2. 答:使用点(.)运算符可以访问Map
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 考试试卷


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!