《数据库系统原理课程设计实验环节.ppt》由会员分享,可在线阅读,更多相关《数据库系统原理课程设计实验环节.ppt(24页珍藏版)》请在三一办公上搜索。
1、数据库系统原理课程设计实验环节3,四川大学计算机学院段磊2011.10,Web数据库应用开发,基础知识两层客户/服务器体系结构 三层客户/服务器体系结构 基于Java的数据库应用,两层客户/服务器(C/S)体系结构,两层客户/服务器(C/S)体系结构,业务逻辑和数据呈现都在客户端胖客户升级复杂数据库服务器 提供企业数据的集成和 管理,三层客户/服务器(B/S)体系结构,三层客户/服务器(B/S)体系结构,客户端仅仅运行用户界面浏览器(Web browser)用于数据的呈现 瘦客户应用服务器运行业务逻辑和数据处理.应用服务器 Web server 数据库服务器提供企业数据的集成和管理.,常用的B
2、/S技术,CGI(通用网关接口)功能 处理用户请求(requests)访问数据库主要优点CGI程序可以用C,C+,或Perl等开发 语言无关性采用编译语言.执行速度快提供地址空间保护 不会影响Web Server主要缺点 由于Http请求的无状态性,不支持跨多个请求的事务。常用进程处理请求 负载重不支持数据库连接池安全性较差,常用的B/S技术,Web服务器脚本Web服务器使用脚本语言(PHP,Perl,Python)来扩展能力相对CGI的优点不需要为每个用户请求创建进程 负荷轻可以与HTML混合编码 开发快Allow database connection pooling.支持数据库连接池缺点
3、不提供地址空间保护 脚本可能使整个服务器崩溃比CGI慢,基于Java的数据应用,Java成为Web计算标准平台无关 类型安全 面向对象 编译代码小 安全性好在Web应用中Java可用于编写JSP(Java Server Pages)和 Servlets服务器应用Servlet Container(容器)JSP和Servlets必须在Servlet Container(如Apache Tomcat)下运行,HTTP简介,HTTP 定义客户端(如IE)如何向 Web 服务器请求文件,以及Web server如何向客户端传回文件Get request 示例GET/path/file.html HTT
4、P/1.0 From:User-Agent:HTTPTool/1.0 blank line here,HTML表单(Forms),HTML forms提供在Web页面中Web客户端向Web服务器送数据的方法表单的html标签.,指定Web服务器端Handler,指定传送请求的方法,HTML表单(Forms),常用的表单元素Text Input Boxes 文本输入框Text Areas 文本区(多行)Password Input Boxes 密码输入框Hidden Fields 隐藏字段File Input 上传文件Radio Buttons 无线按钮Check Boxes 复选框Push B
5、uttons 按钮 Reset按钮 Submit按钮,HTML表单(Forms),示例:User Login Please input your userID and password!,UserID:Password:显示效果,GET与POST方法,表单数据传送可以用GET或POST方法,其请求在对应的Servlet中分别由doGet()和doPost()方法处理。推荐POST方法GET与POST主要区别在与如何传送参数 GET方法把参数放在URL.http:/=navclient&hl=zh-CN&ie=UTF-8&rlz=1T4SUNA_zh-CNCN219CN220&q=postgre
6、s:POST方法则把参数置于request内部,而不在URL中,GET与POST方法,GET方法的request示例GET/path/program.cgi?name=Vince HTTP/1.0 From:User-Agent:HTTPTool/1.0 blank line here,GET与POST方法,POST方法的request示例POST/path/program.cgi HTTP/1.0 From:User-Agent:HTTPTool/1.0 Content-Type:application/x-www-form-urlencoded Content-Length:32 name
7、=Vince,创建简单的Web应用,Eclipse下创建新java project,如test。在test下新建lib目录,复制Tomcat的commonlib目录下servlet.jar文件,并将该目录从build path中Exclude(移出)。在test的properties/java build path/Libraries下点击Add JARs,选定2中复制的servlet.jar。,创建简单的Web应用,在test下新建web目录,将该目录从build path中Exclude。修改test的properties/java build path下的Default output f
8、older为test/web/WEB-INF/classes。以后servlet class放在default package(直接放在test目录下),JSP放在web下。测试时,启动Tomcat。JSP程序的URL为:http:/localhost:8080/test/tt.jsp之类;Servlet的URL为:http:/localhost:8080/test/servlet/HelloServlet之类。,A Hello Servlet Example 1,import;import;import;import;import;import;,A Hello Servlet Exampl
9、e 2,public class HelloWorldExample extends HttpServlet public void doGet(HttpServletRequest request,HttpServletResponse response)throws IOException,ServletException response.setContentType(text/html);PrintWriter out=response.getWriter();,A Hello Servlet Example,out.println();out.println();out.println(Hello World!);out.println();out.println();out.println(Hello World!);out.println();out.println();,A hello JSP Example:,helloJSP.jspHello,JSP,Practice:,熟悉Tomcat的web.xml和server.xml的配置熟悉Eclipse,完成简单的Servlet和JSP程序。测试。,