设为首页 收藏本站
查看: 289|回复: 0

[经验分享] 使用Ant和Tomcat创建Web应用

[复制链接]

尚未签到

发表于 2017-1-30 10:58:16 | 显示全部楼层 |阅读模式
  应当尽量避免使用JSPs实现复杂逻辑;那种程序也许容易写,但难以调试而且几乎不可能被理解和维护。好的解决方案是用JSPs负责Web页面的显示(这正是JSPs擅长的),把复杂逻辑的实现交给Java,如对数据库的访问。这样,程序不但比较容易实现和调试,而且易于理解和维护。    这个Web应用程序可以运行在专用Web服务器或者是个人电脑上,操作系统可以是Windows,Linux,或者Mac OS。所需的软件包有Java运行时环境(JDK1.2或以上版本),Tomcat最新版本(Tomacat 4或以上版本),以及Ant开发工具(Ant 1.4或以上版本)。Ant用于创建Web应用程序包(WAR),以及在Tomcat上安装部署WAR文件,配置关系数据库接口javax.sql.DataSource。所有以上提到的软件包都可以通过Internet免费获得。    【IT168技术文档】这个Web应用程序还需要一个数据库。几乎所有支持SQL而且有JDBC驱动的关系数据库都可以。MySQL是一个符合条件的不错选择。从MySQL.com可以得到MySQL的最新版本以及它的JDBC驱动Connector/J。    为了让Ant与Tomact管理软件协同工作,需要将catalina-ant.jar从Tomcat的server/lib目录拷贝到Ant的lib目录下。将你的数据库JDBC驱动程序复制到Tomcat的common/lib目录下使Tomcat和其上的Web应用程序可以访问数据库。最后,必须建立Tomcat的admin和manager角色(roles),及其用户名和密码,编辑Tomcat的conf目录下的tomcat-user.xml文件如下:    
<!--l version='1.0-->  我的开发环境是Apple Cube,运行Mac OS X 10.2.1操作系统,软件包JDK 1.3.1,Tomcat 4.1.12,Ant1.5.1,MySQL 3.23.52,及Connector/J 3.0.1-beta。操作系统升级到Mac OS X 10.2.2未出现任何问题。同样Tomcat升级到4.1.17也没出现问题。    Web应用程序  本文通过一个叫做AddressBook的简单地址簿程序来说明如何应用将要介绍的技术。这个应用程序的目的不是建立一个地址簿的正式版本,它仅仅是一个例子。    AddressBook中的Java程序  AddressBook中包含三个Java程序。图1显示了他们在Tomcat中的是如何使用的。 AddressBook.ContextListener     AddressBook.ContextListener是一个servlet上下文监听器,它在AddressBook开始和关闭时被调用,可以使用AddressBook的部署描述文件web.xml配置。当AddressBook开始运行时,创建一个AddressesDB的实例并将它作为一个上下文属性保存;而当AddressBook运行结束时,从上下文属性中取出AddressesDB对象并关闭数据库连接。在运行过程中,当JSPs需要连接数据库,它们将访问上下文属性中的AddressesDB对象。    细节请看ContextListener.java的完整的,带有注释的源代码。    AddressBook. AddressesDB     AddressBook. AddressesDB用于操作地址数据库。它的构造函数建立一个数据库连接,这个会话可以被多个Web会话共享。这个类提供多个数据库连接函数:    ? getAddress(id)返回用id标识的地址,如果地址没找到则返回null。    ? addAddress(address)添加地址并返回改变的行数    ? deleteAddress(id)删除地址并返回改变的行数    ? getAddresses()返回数据库中所有地址的聚集,如果数据库无效返回null     ? close()关闭数据库连接    细节请看AddressesDB.java的完整的,带有注释的源代码。    AddressBook. Address     AddressBook. Address是用于描述地址的类。在用JSPs编程时,用类集中描述数据仍不失为一个好的方法。在AddressBook中使用的就是这种方法。    AddressBook. Address的构造函数将地址内容保存于对象中。这个类中包括取得单个地址域的普通get函数,两个获取合并的地址域的get函数,以及一个地址比较函数:    ? Address(id,surname,fisrtname,street,district,city,postcode)     ? getId()     ? getSurname()     ? getFirstname()     ? getStreet()     ? getDistrict()     ? getCity()     ? getPostcode()     ? getFullname()返回firstname+” ”+surname     ? getFulladdress()返回street+” ”+district+” ”+city+” ”+postcode     ? compareTo(address)返回负整数、零、正整数,分别对应surname和firstname大于、等于、小于这个surname和firstname,比较是大小写不敏感的。在存储地址聚集时使用。    细节请看Address.java的完整的,带有注释的源代码。    AddressBook中的JSP页面  AddressBook有七个JSP页。每个代表一个对AddressBook数据库进行独立操作的Web页。每个页面数据库的状态与前页数据库的状态是相互独立的。如果数据库被其他用户改变了,Web页面将检测到并产生相应的动作。例如,如果你正在修改一个地址而另一个用户在确认修改之前删除了该地址,JSP将通知你修改不存在的地址失败。    图2显示JSPs之间的逻辑关系。 Home.jsp是AddressBook的主页,也就是用户使用AddressBook时见到的第一个页面。它用一个表显示Address库中的所有地址。表中的每一行显示一个地址,以及删除或修改地址的连接。页面底部有一个添加新地址的连接。配置信息见web.xml notes。    · 添加地址连接将控制权交给RequestAdd.jsp     · 删除地址连接将控制权交给RequestDelete.jsp,同时将要删除的地址id传递给该页    · 修改地址连接将控制权交给RequestModify.jsp,同时将要修改的地址id传递给该页    细节请看Home.jsp的完整的,带有注释的源代码。    RequestAdd.jsp     RequestAdd.jsp提供一个地址表单用于输入新地址。页面底部的取消连接可以取消这次操作。    · 提交表单将新的地址域值以及控制权交给DoAdd.jsp     · 取消操作将控制权交给Home.jsp     细节请看RequestAdd.jsp的完整的,带有注释的源代码。    DoAdd.jsp     DoAdd.jsp显示接收到的地址域值。然后将新地址添加到数据库并显示是否成功的信息。页面底部有一个继续连接。    · 点击继续连接回到Home.jsp     细节请看DoAdd.jsp的完整的,带有注释的源代码。    RequestDelete.jsp     RequestDelete.jsp读取得到的id相应的地址。该页面在表中显示地址域以便让你确认删除的是正确的地址。页面底部的两个连接分别是继续请求的继续连接和取消请求的取消连接。    · 选择继续连接将转到DoDelete.jsp并传递要删除的地址id     · 选择取消连接回到Home.jsp     细节请看RequestDelete.jsp的完整的,带有注释的源代码。    DoDelete.jsp     DoDelete.jsp读取传递给它的id。在表中显示该id对应的地址,从数据库中删除它,并显示是否成功。页面底部是继续连接。    · 选择继续连接回到Home.jsp     细节请看DoDelete.jsp的完整的,带有注释的源代码。    RequestModify.jsp     RequestModify.jsp显示一个表单并填入当前的地址,同时提供提交按钮和取消连接。    · 提交表单将新的地址域值以及控制权交给DoModify.jsp     · 选择取消连接回到Home.jsp     细节请看RequestModify.jsp的完整的,带有注释的源代码。    DoModify.jsp     DoModify.jsp显示接收到的修改的地址域值。然后修改数据库中的地址记录,并返回成功与否。页面底部是继续连接。    · 选择继续连接回到Home.jsp     细节请看DoModify.jsp的完整的,带有注释的源代码。    AddressBook的Addresses数据库表    如何建立数据库取决于所用的数据库软件。若你用的不是MySQL以下的步骤就需要根据情况修改。AddressBook只有一个表Addresses,保存在数据库Public中。表Addresses有七个域:    · id,主键,自动增长的数据域    · surname,长度为24的字符域,保存联系人的姓    · firstname,长度为24的字符域,保存联系人的名    · street,长度为80的字符域,保存地址的第一行    · district,长度为80的字符域,保存地址的第二行    · city,长度为40的字符域,保存城市名    · postcode,长度为10的字符域,保存邮政编码    首先建立MySQL数据库(Mac OS X 10.2.1)。用管理员权限启动mysql命令行工具,需要的话输入密码。创建Public数据库,以及账号mysqlusername密码mysqlpassord。命令如下:    # mysql -u root -p   mysql> create database Public;   mysql> grant all privileges on Public.* to mysqlusername@localhost identified by 'mysqlpassword' wi

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-335242-1-1.html 上篇帖子: 一步一步实现CAS与Tomcat配置 下篇帖子: tomcat_DBCP连接池配置解释_摘抄
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表