jsp介绍及优缺点比较,webform设计思路的思考

   
 我使用asp.net的webform框架进行web应用程序的开发已经差不多四年了,在整个开发生涯中,也使用过一年asp.net的mvc框架。因为网上经常有讨论webform框架和mvc框架的优劣,所以自己也对这两者进行了关注,因为自己最熟悉webform框架,所以就会考虑它的优势是什么?设计思路是什么?

现在主流的网站开发语言无外乎asp、php、asp.net、jsp等。

   
要理解asp.net的设计思路,必须考虑它的产生年代,产生的技术基础,还有观察同时代其他动态网页技术的特点和思路。

网页从开始简单的hmtl到复杂的服务语言,走过了10多个年头,各种技术层出不穷,单个的主流技术也在不断翻新的版本,现在分析下各种语言的区别、优势、劣势、开发注意事项!

   首先是产生asp.net的技术基础,以下援引百度百科:

HTML:当然这是网页最基本的语言,每一个服务器语言都需要它的支持,要学习,这个肯定是开始,不说了.

*   “1996年,ASP 1.0(Active Server
Pages)版本出现了,它引起了Web开发的新革命,降低了动态网页开发的难度。以前开发动态网页需要编写大量繁杂的C代码,编程效率非常低下,而且需要Web网页开发者掌握非常高的编程技巧。而ASP使用简单的脚本语言,能够将代码直接嵌入HTML,使设计Web页面变得更简单。虽然ASP非常简单,但却能够实现非常强大的功能,这一切得益于其组件。特别是ADO组件,使得在网页中访问数据库易如反掌。这一切推动了动态网页的快速发展与建设,同时使ASP得到迅速流行。*

主流网站开发语言之ASP:ASP是微软(Microsoft)所开发的一种后台脚本语言,它的语法和Visual
BASIC类似,可以像SSI(Server Side
Include)那样把后台脚本代码内嵌到HTML页面中。虽然ASP简单易用,但是它自身存在着许多缺陷,最重要的就是安全性问题。目前在微软的
.net 战略中新推出的ASP.net 借鉴了Java技术的优点,使用C Sharp (C#)
语言作为ASP.net的推荐语言,同时改进了以前ASP的安全性差等缺点。但是,使用ASP/ASP.net仍有一定的局限性,因为从某种角度来说它们只能在微软的
Windows NT/2000/XP +
IIS的服务器平台上良好运行(虽然像ChilliSoft提供了在UNIX/Linux上运行ASP的解决方案,但是目前ASP在UNIX/Linux上的应用可以说几乎为0)。所以平台的局限性和ASP自身的安全性限制了ASP的广泛应用。
ASP在执行的时候,是由IIS调用程序引擎,解释执行嵌在HTML中的ASP代码,最终将结果和原来的HTML一同送往客户端。

*    1998年,微软公司发布了ASP 2.0,它是作为Windows NT 4 Option
Pack的一部分提供的。ASP 2.0与ASP
1.0的主要区别是外部的组件可以初始化,使所有的组件都有了独立的内存空间,并且可以进行事务处理。内置的Microsoft
Transaction Server(MTS)使制作组件变得更容易。*

主流网站开发语言之PHP:PHP 的全名非常有趣,它是一个巢状的缩写名称——“PHP:
Hypertext Preprocessor”,打开缩写还是缩写。PHP是一种HTML 内嵌式的语言
(就像上面讲的ASP那样)。而 PHP 独特的语法混合了C,Java,Perl以及 PHP
式的新语法。它可以比 CGI 或者 Perl 更快速地执行动态网页。
PHP的源代码完全公开,在 Open Source
意识抬头的今天,它更是这方面的中流砥柱。不断地有新的函数库加入,以及不停地更新,使得
PHP 无论在 UNIX 或是 Win32
的平台上都可以有更多新的功能。它提供丰富的函数,使得在程式设计方面有着更好的资源。目前PHP的最新版本为4.1.1
,它可以在Win32以及UNIX/Linux等几乎所有的平台上良好工作。PHP在4.0版后使用了全新的Zend引擎,其在最佳化之后的效率,比较传统
CGI 或者 ASP 等技术有了更好的表现。
平台无关性是PHP的最大优点,但是在优点的背后,还是有一些小小的缺点的。如果在PHP中不使用ODBC,而用其自带的数据库函数(这样的效率要比使用ODBC高)来连接数据库的话,
使用不同的数据库,PHP的函数名不能统一。这样,使得程序的移植变得有些麻烦。不过,作为目前应用最为广泛的一种后台语言,PHP的优点还是异常明显的。

*   
2000年6月,微软公司宣布了自己的.NET框架。.NET框架的基本思想是:把原有的重点从连接到互联网的单一网站或设备转移到计算机、设备和服务群组上,而将互联网本身作为新一代操作系统的基础。这样,用户将能够控制信息的传送方式、时间和内容,从而得到更多的服务。*

ASP.NET:ASP.net是Microsoft.net的一部分,作为战略产品,不仅仅是 Active
Server Page (ASP) 的下一个版本;它还提供了一个统一的 Web
开发模型,其中包括开发人员生成企业级 Web 应用程序所需的各种服务。ASP.NET
的语法在很大程度上与 ASP
兼容,同时它还提供一种新的编程模型和结构,可生成伸缩性和稳定性更好的应用程序,并提供更好的安全保护。可以通过在现有
ASP 应用程序中逐渐添加 ASP.NET 功能,随时增强 ASP
应用程序的功能。ASP.NET 是一个已编译的、基于 .NET 的环境,可以用任何与
.NET 兼容的语言(包括 Visual Basic .NET、C# 和 JScript
.NET.)创作应用程序。另外,任何 ASP.NET 应用程序都可以使用整个 .NET
Framework。开发人员可以方便地获得这些技术的优点,其中包括托管的公共语言运行库环境、类型安全、继承等等。ASP.NET
可以无缝地与 WYSIWYG HTML 编辑器和其他编程工具(包括 Microsoft Visual
Studio .NET)一起工作。这不仅使得 Web
开发更加方便,而且还能提供这些工具必须提供的所有优点,包括开发人员可以用来将服务器控件拖放到
Web 页的 GUI
和完全集成的调试支持。微软为ASP.net设计了这样一些策略:易于写出结构清晰的代码、代码易于重用和共享、可用编译类语言编写等等,目的是让程序员更容易开发出Web应用,满足计算向Web转移的战略需要。

*   
2001年,ASP.NET浮出水面。它最初的名字为ASP+,后来改为ASP.NET。ASP.NET是微软公司开发的一种建立在.NET之上的Web运行环境,它不是ASP的简单升级,而是新一代的Active
Server
Pages。ASP.NET是微软公司新体系结构Microsoft.NET的一部分,其中全新的技术架构使编程变得更加简单。借助于ASP.NET,可以创造出内容丰富的、动态的、个性化的Web站点。ASP.NET简单易学、功能强大、应用灵活、扩展性好,可以使用任何.NET兼容语言。 [4-5] *

 

*    2002年微软发布.NET正式版本.NET Framework
1.0,其中的ASP版本就是ASP.NET
1.0,在此以前发布了两个.NET测试版本Betal和Beta2。*

主流网站开发语言之JSP:JSP和Servlet要放在一起讲,是因为它们都是Sun公司的J2EE(Java
2 platform Enterprise Edition)应用体系中的一部分。
Servlet的形式和前面讲的CGI差不多,它是HTML代码和后台程序分开的。它们的启动原理也差不多,都是服务器接到客户端的请求后,进行应答。不同的是,CGI对每个客户请求都打开一个进程(Process),而Servlet却在响应第一个请求的时候被载入,一旦Servlet被载入,便处于已执行状态。对于以后其他用户的请求,它并不打开进程,而是打开一个线程(Thread),将结果发送给客户。由于线程与线程之间可以通过生成自己的父线程(Parent
Thread)来实现资源共享,这样就减轻了服务器的负担,所以,Java
Servlet可以用来做大规模的应用服务。
虽然在形式上JSP和ASP或PHP看上去很相似——都可以被内嵌在HTML代码中。但是,它的执行方式和ASP或PHP完全不同。在JSP被执行的时候,JSP文件被JSP解释器(JSP
Parser)转换成Servlet代码,然后Servlet代码被Java编译器编译成 .class
字节文件,这样就由生成的Servlet来对客户端应答。所以,JSP可以看做是Servlet的脚本语言(Script
Language)版。
由于JSP/Servlet都是基于Java的,所以它们也有Java语言的最大优点——平台无关性,也就是所谓的“一次编写,随处运行(WORA
– Write Once, Run
Anywhere)”。除了这个优点,JSP/Servlet的效率以及安全性也是相当惊人的。因此,JSP/Servlet虽然在国内目前的应用并不广泛,但是其前途不可限量。
在调试JSP代码时,如果程序出错,JSP服务器会返回出错信息,并在浏览器中显示。这时,由于JSP是先被转换成Servlet后再运行的,所以,浏览器中所显示的代码出错的行数并不是JSP源代码的行数,而是指转换后的Servlet程序代码的行数。这给调试代码带来一定困难。所以,在排除错误时,可以采取分段排除的方法(在可能出错的代码前后输出一些字符串,用字符串是否被输出来确定代码段从哪里开始出错),逐步缩小出错代码段的范围,最终确定错误代码的位置。

*    2003年微软发布了.NET Frameworrk 1.1正式版,其中ASP版本就是ASP.NET
1.1。*

主流网站开发语言之CGI:CGI就是公共网关接口 (Common Gateway Interface)
的缩写。它是最早被用来建立动态网站的后台技术。这种技术可以使用各种语言来编写后台程序,例如C,C++,Java,Pascal等,但是目前在CGI中使用的最为广泛的是Perl语言。所以,狭义上所指的CGI程序一般都是指Perl程序,一般CGI程序的后缀都是.pl或者.cgi

CGI程序在运行的时候,首先是客户向服务器上的CGI程序发送一个请求,服务器接收到客户的请求后,就会打开一个新的Process(进程)来执行CGI程序,处理客户的请求。CGI程序最后将执行的结果(HTML页面代码)传回给客户。
由于CGI程序每响应一个客户就会打开一个新的进程,所以,当有多个用户同时进行CGI请求的时候,服务器就会打开多个进程,这样就加重了服务器的负担,使服务器的执行效率变得越来越低下。这也就是最近几年来随着各种新的后台技术的诞生,CGI应用在Internet上越来越少的原因。CGI方式不适合大访问量的应用。

*    2005年微软发布.NET Framework 2.0正式版本,也就是ASP.NET 2.0。*”

如今主流的Web服务器软件主要由IIS或Apache组成。IIS支持ASP且只能运行在Windows平台下,Apache支持PHP,CGI,JSP且可运行于多种平台,虽然Apache是世界使用排名第一的Web服务器平台,但是众所周知,Windows以易用而出名,也因此占据不少的服务器市场。

 

我们常用的开发组合:

   
这是一段引自百度百科,介绍从asp发展到asp.net的记述。阅读这段记述你应该意识到,asp.net是从asp1.0开始发展来的,但是它不是直接从asp发展到asp.net的,首先是asp1.0,然后是asp2.0,然后是asp+,再然后改名为asp.net(这里如果分开看就是asp
 、
 .net这是两个词,因为在asp的发展过程中另一个大的项目.net出现了,.net为什么出现,不在讨论范围,可以自行百度)。asp.net1.1技术的web框架就是webform。

IIS环境下
1.ASP+ACCESS
2.ASP+SQL SERVER
3.ASP.NET+ACCESS
4.ASP.NET+SQL SERVER
APACHE环境下
5.jsp+Oracale
6.JSP+MYSQL
7.PHP+MYSQL

    虽然我没打算梳理叙述.net的产生和发展,但是asp.net
webform的产生却和.net平台非常紧密。

可以说,asp确实快过时了,在未来jsp和asp.net将会有巨大的潜力,但php凭借其开源的特性也会占有一定份额。 

   
在asp产生的前两年,产生了另外一个非常有名的动态网页技术,那就是PHP。这里援引一下php的概念:

vb一般指vb6.0,是传统的win32编程。vb.net和asp.net是基于微软.net平台的语言。说java好主要是因为java的j2ee部分做企业级开发很强大,而且跨平台。c#是.net平台上最好用的语言,现在只能运行在windows系统。 web开发方面.net和j2ee的竞争很激烈,难说以后鹿死谁手。 现在做网站大部分都是asp.net或jsp的,asp.net容易上手,比较普及,但是平台单一,jsp虽然上手难,但是跨平台,安全性高。

   “PHP(外文名:PHP: Hypertext
Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言。语法吸收了C语言、Java和Perl的特点,利于学习,使用广泛,主要适用于Web开发领域。PHP
独特的语法混合了C、Java、Perl以及PHP自创的语法。它可以比CGI或者Perl更快速地执行动态网页。用PHP做出的动态页面与其他的编程语言相比,PHP是将程序嵌入到HTML(标准通用标记语言下的一个应用)文档中去执行,执行效率比完全生成HTML标记的CGI要高许多;PHP还可以执行编译后代码,编译可以达到加密和优化代码运行,使代码运行更快。”

下面比较一下ASP、ASP.net、JSP和PHP的优点和缺点:

 

ASP优点:

   
php的产生早于asp技术,asp应该是吸收有php技术的建造思想的,之所以称为建造,是因为php的起点非常低,并没有被进行充分的设计,它是从一个小工具快速发展起来的。这里还想提一下另外一个重要的动态网页技术,再次援引下百度百科:

  1. 无需编译
  2. 易于生成
  3. 独立于浏览器
  4. 面向对象
  5. 与任何ActiveX scripting 语言兼容
  6. 源程序码不会外漏

缺点:
1、Windows本身的所有问题都会一成不变的也累加到了它的身上。安全性、稳定性、跨平台性都会因为与NT的捆绑而显现出来。
2、ASP由于使用了COM组件所以它会变的十分强大,但是这样的强大由于Windows
NT系统最初的设计问题而会引发大量的安全问题。只要在这样的组件或是操作中一不注意,哪么外部攻击就可以取得相当高的权限而导致网站瘫痪或者数据丢失。
3、由于ASP还是一种Script语言所没除了大量使用组件外,没有办法提高其工作效率。它必须面对即时编绎的时间考验,同时我们还不知其背后的组件会是一个什么样的状况。
4、无法实现跨操作系统的应用。当然这也是微软的理由之一,只有这样才能发挥ASP最佳的能力。可是我却认为正是Windows限制了ASP,ASP的概念本就是为一个能让系统运行于一个大的多样化环境而设计的。
5、还无法完全实现一些企业级的功能:完全的集群、负载均横。

    “JSP全名为Java Server
Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计,它 [1]  是由Sun
Microsystems公司倡导、许多公司参与一起建立的一种动态网页技术标准。JSP技术有点类似ASP技术,它是在传统的网页HTML(标准通用标记语言的子集)文件(\
.htm,*.html)中插入Java程序段(Scriptlet)和JSP标记(tag),从而形成JSP文件,后缀名为(*.jsp)。
用JSP开发的Web应用是跨平台的,既能在Linux下运行,也能在其他操作系统上运行。*

ASP.NET优点:
1. 简洁的设计和实施。
2. 语言灵活,并支持复杂的面向对象特性。
3. 开发环境。

它实现了Html语法中的java扩展(以 <%,
%>形式)。JSP与Servlet一样,是在服务器端执行的。通常返回给客户端的就是一个HTML文本,因此客户端只要有浏览器就能浏览。

缺点:
1.数据库的连接复杂。

*   
JSP技术使用Java编程语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页还能通过tags和scriptlets访问存在于服务端的资源的应用逻辑。JSP将网页逻辑与网页设计的显示分离,支持可重用的基于组件的设计,使基于Web的应用程序的开发变得迅速和容易。
JSP(JavaServer
Pages)是一种动态页面技术,它的主要目的是将表示逻辑从Servlet中分离出来。*

JSP优点:
1、     一处编写随处运行。
2、     系统的多台平支持。
3、     强大的的可伸缩性。
4、     多样化和功能强大的开发工具支持。

Java Servlet是JSP的技术基础,而且大型的Web应用程序的开发需要Java
Servlet和JSP配合才能完成。JSP具备了Java技术的简单易用,完全的面向对象,具有平台无关性且安全可靠,主要面向因特网的所有特点。

缺点:
1、     与ASP一样,Java的一些优势正是它致命的问题所在。
2、     缺少系统性的资料。
3、     速度超慢

 
 JSP技术比php、asp技术产生的更晚,JSP技术现在被用来开发超大型网站,但是并不是因为JSP技术本身非常优秀,而是因为它产生于java之上。

PHP优点:
1、     一种能快速学习、跨平台、有良好数据库交互能力的开发语言。
2、     简单轻便,易学易用。
3、     与Apache及其它扩展库结合紧密。
4、     良好的安全性。

 
 这个时代的asp、php、jsp等动态网页技术,都有一个共同点,就是你访问url地址,肯定是存在一个这样一个文件存在的。asp.net产生的技术基础是asp,那么asp.net的webform框架使用这同一思想就顺理成章了。webform的页面文件有两部分,后缀名是.aspx和.aspx.cs两部分组成。这个是有别于asp的,asp页面文件只有一个,后缀名是.asp。从.asp到.aspx我们可以看到,aspx是在asp的后面加了x字母,联想微软的其他产品,.docx取代.doc、.xlsx取代.xls,多少可以窥探到微软对技术升级的命名思考。

缺点:
1、     数据库支持的极大变化。
2、     不适合应用于大型电子商务站点
3、     安装复杂。
4、     缺少正规的商业支持。
5、     无法实现商品化应用的开发。

   以上叙述,讲到了asp.net
 webform将页面文件拆分成了两个部分。这是很大的一个改进,这种改进是为了解决一些问题(不是一个,是一系列问题)。改进asp技术cs代码和html混在一起,暴露代码细节,asp页面不会被编译成dll。同时也有其他优势。

   从asp到asp.net,在webform框架中大量内置了ASP.NET
服务器控件,这是一个很大的改变,这种服务器控件分三种:

  • HTML 服务器控件 – 传统的 HTML 标签
  • Web 服务器控件 – 新的 ASP.NET 标签
  • Validation 服务器控件 – 用于输入验证

网上有人说,这是为了解决开发asp页面会造成意大利面条的问题。我的理解服务器控件的改变远不止于此,假如你创建一个纯服务器控件的页面(asp.net出现不久,很多人就不建议这么干了,至于为什么,我知道会生成大量viewstate串,当然还有其他原因),然后对页面元素进行操作,随着使用的熟练,你可能会意识到webform的页面文件不是在html字符中间拼东西,或者说不是在一堆服务器无法理解的东东中间,动态的生成一些字符。它前进了很多步,它把页面的所有html便签加上标识,经过页面引擎处理,变成了可以被灵活操作的类,程序开发人员可以随意操作这些标签类,然后在一个合适的时候,再将这些类顺序的“ToString()”成字符串,拼到页面上。发明服务器控件技术,作者的思想来源可能是桌面应用程序开发技术,从dos操作系统(命令行交互),到视窗操作系统(主要是鼠标点击、键盘按键交互),开发桌面应用程序,会大量使用控件技术,控件复用技术可以大大提升开发效率。为什么猜测作者的思想可能来源于此,因为asp技术出现时,当时桌面应用程序开发还是主流,作者可能浸染在这种氛围内,把桌面应用程序开发的设计思想转移至web程序的开发。这里要引出另外一个东西,就是事件驱动,随便新建一个aspx页面,最重要的是事件处理方法,Page_Load。windows操作系统中大量使用事件驱动,是基于“事件驱动模型”的。那么作者在webform中使用事件驱动,也可能借鉴了windows。

   
不管是服务器控件,还是事件驱动,这两种(或者说是一种,因为控件和事件之间本就相互关联)设计思想很大的影响了webform框架,开发web应用程序的方式。服务器控件加事件驱动虽然利于很快开发一个管理系统型web程序,但是并不符合web应用程序本身的运行思想,这一点被很多人批评,web程序因为不运行在桌面操作系统中,最早的时候它甚至不能交互,只是为了便于交流信息,只用于展示信息。web程序本质运行原理是,通过浏览器向web服务器发送请求处理命令,有web托管程序接收请求命令,进行操作,然后返回处理结果(结果可能是展示一篇文章,或者是告诉你文章删除成功,或者是将你提价的信息内容进行了保存)。webform容易让人误会它运行在操作系统或者浏览器中,所有代码执行在客户端。虽然现在的浏览器真的可以将动态页面放在浏览器端执行,但是webform页面其实是有服务器端的程序处理的。

   
如果要评价和审视webform框架的设计思想,不得不对比另外一个框架思想,那就是mvc的框架(模型)的设计思想。mvc模型的发明,或许不是刻意设计,而是对事情的深入思考,然后抓住本质的产物。mvc模型是为了处理问题清晰明了,降低耦合性。

   
由于不会php和jsp就没办法对比这两种技术了,其实很想把它们也拉进来对比下,特别是jsp技术,因为java的跨平台性,jsp设计时不会有太多windows的影子,windows常常有种不想告诉你复杂的真相,所以我给你包装一个简单的世界给你的感觉,然后随着你的成长,这种早期的包装可能会是一个大的负担,或者说微软的东西有太多windows的影子,过于围绕windows了。

   
最后总结一下,如果你放开自己紧张的神经,不给自己设限,随意联想,随意设计,不过于考虑完美,你会感觉到web技术发展一些思想的传承和变革。从简单的html纯文本展示,文本浏览器的发明,背后的http协议0.9,再到图片展示,LiveScript的发明(就是javascript),到CGI程序,再到Servlet拼接html技术,到php脚本,到asp动态页面技术,到jsp动态页面技术,到webfrom框架,spring框架,mvc框架这些技术背后隐隐有一条思想在串联起来。一个东西的发明不是偶然的,往往有一个不起眼的起始。

    

 

 

阅读本文请注意,假如你感觉混乱,那么就不要阅读引用的部分,可以大概先只阅读其他内容。

本文并没有进行认真的考察和检验,有的地方可能是错误的,一些技术的发明先后也可能并不准确。但是希望文中关注一个技术的发展历史的思路,能给你学习提供一点助益。

 

 

 

 

 

 

 

 

Post Author: admin

发表评论

电子邮件地址不会被公开。 必填项已用*标注