外文翻譯--mysql和jsp的web應(yīng)用程序_第1頁(yè)
已閱讀1頁(yè),還剩13頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  MySQL和JSP的Web應(yīng)用程序</p><p>  JSP開(kāi)發(fā)人員構(gòu)建Web應(yīng)用程序時(shí)遇到需要強(qiáng)大的數(shù)據(jù)庫(kù)連接的特殊問(wèn)題。 MySQL和JSP的Web應(yīng)用程序解決了構(gòu)建數(shù)據(jù)驅(qū)動(dòng)的應(yīng)用程序JavaServer頁(yè)面上的發(fā)展模式為基礎(chǔ)的挑戰(zhàn)。 MySQL和JSP的Web應(yīng)用程序開(kāi)始一個(gè)對(duì)JSP數(shù)據(jù)庫(kù)開(kāi)發(fā) - JavaServer頁(yè)面,JDBC和數(shù)據(jù)庫(kù)模式所需的核心技術(shù)概述。該書(shū)然后概述并提出了

2、互聯(lián)網(wǎng)商業(yè)應(yīng)用演示,如接收和處理用戶輸入,設(shè)計(jì)和實(shí)施業(yè)務(wù)規(guī)則,并平衡服務(wù)器上的用戶負(fù)載的概念。通過(guò)JDBC(Java數(shù)據(jù)庫(kù)連接),開(kāi)發(fā)人員能夠與大多數(shù)商業(yè)數(shù)據(jù)庫(kù)如Oracle進(jìn)行溝通。在MySQL和JSP的Web應(yīng)用中心提交了一份關(guān)于開(kāi)源工具M(jìn)ySQL和Tomcat的解決方案,使讀者一個(gè)經(jīng)濟(jì)實(shí)惠的方式來(lái)測(cè)試書(shū)中的例子的應(yīng)用程序和試驗(yàn)。</p><p>  那么JSP是怎么一回事呢?</p><

3、p>  如果您符合上述要求的,你對(duì)這個(gè)問(wèn)題的答案應(yīng)該已經(jīng)有一個(gè)相當(dāng)不錯(cuò)的理解。 JSP是所有關(guān)于做高度面向?qū)ο蟮木W(wǎng)站,可以利用所有的現(xiàn)代軟件工程最佳實(shí)踐。這些做法包括諸如SQL數(shù)據(jù)庫(kù)和基于UML設(shè)計(jì)的東西。這并不是說(shuō)JSP是萬(wàn)能的而且使用它會(huì)自動(dòng)將您的網(wǎng)站上的工程藝術(shù)的典范。這只是盡可能地用其他任何技術(shù)用JSP設(shè)計(jì)不良網(wǎng)站。這就是為什么,當(dāng)你詳細(xì)檢查文本的時(shí)候,你會(huì)看到如何合并最佳方法以及項(xiàng)目得到的壓力時(shí)候如何避免方便的陷阱。JS

4、P它本身就是從第一個(gè)靜態(tài)Web服務(wù)器開(kāi)始的一個(gè)沿路徑循序漸進(jìn)的步驟,通過(guò)CGI移動(dòng)功能的服務(wù)器,最后腳本功能的服務(wù)器的第一代。 JSP是一個(gè)比Java引擎能夠熟悉網(wǎng)頁(yè)的的少了一個(gè)Java組件的Web服務(wù)器。</p><p>  JSP是由Java servlet發(fā)展演變而來(lái)的。servlet允許開(kāi)發(fā)人員處理傳入使用Java程序能夠訪問(wèn)的所有正常的信息,一個(gè)共同的網(wǎng)關(guān)接口(CGI)程序?qū)eb請(qǐng)求。此外,該serv

5、let可以訪問(wèn)會(huì)話持久對(duì)象。這是Java的都與一個(gè)特定的用戶會(huì)話,可用于存儲(chǔ)請(qǐng)求之間的狀態(tài)對(duì)象。 Servlet編程是一個(gè)允許開(kāi)發(fā)人員編寫(xiě)結(jié)構(gòu)良好的模塊化的Web應(yīng)用程序使用面向?qū)ο笳Z(yǔ)言的重要一步。它還解決了狀態(tài)持久性的問(wèn)題,用戶和應(yīng)用程序執(zhí)行的一個(gè)動(dòng)作或一系列動(dòng)作期間讓更多的信息駐留在服務(wù)器上而且較少的反復(fù)在用戶和服務(wù)器之間傳遞。 Servlet還遭受一大問(wèn)題。因?yàn)樗麄冏罱K需要輸出HTML中,HTML編碼必須被嵌入在servlet代碼

6、中。導(dǎo)致如下所示的一段代碼片段:</p><p>  Out.println("<HTML>\n<HEAD>\n<TITLE>Thank you for </p><p>  Registering</TITLE></HEAD>\n"); </p><p>  Out.println(&

7、quot;<IMG SRC=\"thanks.jpg\" WIDTH=200 HEIGHT=100 ALIGN=\"LEFT\”>"); </p><p>  當(dāng)你編碼很多網(wǎng)頁(yè)時(shí),這種嵌入式是非常古老非??斓?。此外,必須避免所有引號(hào)會(huì)導(dǎo)致的很多混亂和如果你遺漏了一個(gè)反斜杠帶來(lái)難以發(fā)現(xiàn)的錯(cuò)誤。最終,一個(gè)較好的方法出現(xiàn)。假設(shè)你能結(jié)合最好的靜態(tài)HTML頁(yè)面和servl

8、et的交互能力。其結(jié)果是JavaServer頁(yè)面(在微軟方面,結(jié)果是活動(dòng)服務(wù)器頁(yè)面)。JSP是非常復(fù)雜強(qiáng)大的。在接下來(lái)的章節(jié)中,你會(huì)通過(guò)這個(gè)細(xì)節(jié)流程,但就目前而言,這里是主要的步驟:</p><p>  1、接到請(qǐng)求時(shí)從使用普通的HTTP請(qǐng)求格式的瀏覽器。</p><p>  2、WEB服務(wù)器切換到JSP的請(qǐng)求,JSP著眼于找到合適的JSP文件。</p><p> 

9、 3、.jsp文件轉(zhuǎn)換成.Java文件,包含Java代碼,將創(chuàng)建一個(gè)類,它的名稱是從.jsp的文件名而得。</p><p>  4、JSP然后用javac編譯.java文件產(chǎn)生一個(gè).class文件。注意如果一個(gè).class文件已經(jīng)存在而且比.jsp文件新則可以跳過(guò)先前的兩步。</p><p>  5、一個(gè)新創(chuàng)建的類實(shí)例被實(shí)例化,并發(fā)送_jspService消息。</p>&l

10、t;p>  6、新的實(shí)例看看是否已經(jīng)有一個(gè)被稱為user的stuff.User對(duì)象實(shí)例在當(dāng)前連接的用戶會(huì)話對(duì)象的空間存在。如果沒(méi)有,一個(gè)實(shí)例被實(shí)例化。</p><p>  7、作為服務(wù)stuff.jsp的一部分,user實(shí)例將被GetUserName()方法調(diào)用。</p><p>  8、如果JSP處理需要訪問(wèn)數(shù)據(jù)庫(kù)中的信息,它將使用JDBC來(lái)進(jìn)行連接和處理SQL請(qǐng)求。</p&

11、gt;<p>  正如你可以看到,巨大的能量是在現(xiàn)有的JSP世界里。開(kāi)發(fā)者可以自由編寫(xiě)大多數(shù)看起來(lái)像HTML的Web頁(yè)面,除非到Java標(biāo)注是要求最喜歡看的HTML。但是,在同一時(shí)間,他們可以自由地充分發(fā)展充實(shí)面向?qū)ο蟮膽?yīng)用程序使用Java會(huì)帶來(lái)負(fù)擔(dān)的所有功能。他們也得到servlet的所有優(yōu)點(diǎn),包括會(huì)話持久性。</p><p>  為什么我們需要的數(shù)據(jù)庫(kù)?</p><p>

12、  好,一個(gè)原因就是為了讓拉里埃里森想到比爾蓋茨的時(shí)候,他的Oracle有能力保持自己百憂解。更嚴(yán)重的回答是相同的原因也就是駕駛?cè)讼劝聪箩槍?duì)一塊濕粘泥:因?yàn)榘咽虑橛浵聛?lái)是好的。 Web服務(wù)器是了不起的創(chuàng)造,但他們是一個(gè)有點(diǎn)像白癡專家。請(qǐng)他們?yōu)橐粋€(gè)網(wǎng)頁(yè)或運(yùn)行Java的一段,他們表演的像一個(gè)冠軍。但開(kāi)始要求他們記住他們五分鐘前做了什么,和他們顯露的比一個(gè)肥皂劇里的人物失憶還快。</p><p>  第一個(gè)也是最重要的

13、原因是你使用的數(shù)據(jù)庫(kù)是有大量的數(shù)據(jù)在電子商務(wù)交易里,你必須記住并跟蹤:</p><p>  ?一個(gè)用戶的姓名,地址,信用卡和其他信息以前進(jìn)入了一個(gè)注冊(cè)頁(yè)面</p><p>  ?帽子的用戶可能把以前留下交易放進(jìn)購(gòu)物車</p><p>  ?哪些物品有存貨,以及它們的價(jià)格,描述等等</p><p>  ?訂單需要履行,訂單已發(fā)貨,并已待補(bǔ)物品。

14、</p><p>  現(xiàn)在,你可以存儲(chǔ)所有這些信息在服務(wù)器上的硬盤(pán)平面文件中,但也有你想保存的數(shù)據(jù)的其他重要屬性:</p><p>  ?如果交易部分失敗,您希望能夠收回交易。</p><p>  ?您希望能夠找到Web服務(wù)器安全的地方定位數(shù)據(jù),這可能是完全在DMZ或外部的防火墻。</p><p>  ?您希望能夠如用戶數(shù)據(jù)或產(chǎn)品快速訪問(wèn)數(shù)據(jù)

15、,即使有數(shù)千或上百萬(wàn)數(shù)據(jù)。</p><p>  當(dāng)你添加這些項(xiàng)目的購(gòu)物清單,只有一個(gè)關(guān)系數(shù)據(jù)庫(kù)才會(huì)真正的影響工作效率。</p><p><b>  MySQL </b></p><p>  許多網(wǎng)站不需要Oracle的歷史優(yōu)勢(shì)(和價(jià)格標(biāo)簽)。 MySQL是一個(gè)開(kāi)源SQL數(shù)據(jù)庫(kù)可供任何人使用,擁有許多(盡管不是全部)的先前數(shù)據(jù)庫(kù)的功能,如Orac

16、le。</p><p>  MySQL是可用于幾乎所有的電腦上有相當(dāng)好的能力是相當(dāng)輕量級(jí)的處理器,安裝方便(10分鐘,而不像Oracle需要多個(gè)小時(shí))。</p><p>  所以,也許你想知道,有什么收獲?沒(méi)有得到什么,你在MySQL中,使人們把目光轉(zhuǎn)向到Oracle?那么,MySQL是一個(gè)不錯(cuò)的小程序包,但它缺少一些東西,不然會(huì)是不錯(cuò)的一個(gè)完美的世界。</p><p&

17、gt;  一個(gè)主要特點(diǎn)就是MySQL不提供數(shù)據(jù)庫(kù)一致性檢查。您可以使用您的模式外鍵的標(biāo)簽,但MySQL會(huì)忽略它們。據(jù)我所知許多數(shù)據(jù)庫(kù)管理員會(huì)認(rèn)為這是一個(gè)很糟糕的事情。</p><p>  外鍵約束防止你創(chuàng)建數(shù)據(jù)不一致。例如,假設(shè)你有一個(gè)像這樣的數(shù)據(jù)庫(kù)表:</p><p>  CREATE TABLE USER ( </p><p>  USERID INTEGER,

18、 </p><p>  FIRST_NAME VARCHAR(80), </p><p>  LAST_NAME VARCHAR(80)); </p><p>  CREATE TABLE PURCHASE ( </p><p>  USERID FOREIGN KEY USER(USERID), </p>&

19、lt;p>  ITEM INTEGER, </p><p>  QUANTITY INTEGER); </p><p>  在諸如Oracle的數(shù)據(jù)庫(kù)里,如果你創(chuàng)建了一個(gè)在PURCHASE 表ID為3的用戶輸入數(shù)據(jù)庫(kù),在USER表里可能已經(jīng)有一個(gè)ID為3的用戶或錯(cuò)誤會(huì)發(fā)生。同樣,如果它在PURCHASE理是作為參考,你就不能從表USER里刪除ID為3的用戶,MySQL的人們做了一個(gè)漂

20、亮慷慨激昂的論點(diǎn)關(guān)于在各自的文檔進(jìn)行數(shù)據(jù)的完整性取決于外鍵是無(wú)論如何都是一個(gè)壞主意,但是說(shuō)服你的這種哲學(xué)的DBA是很可能淪為一個(gè)宗教辯論,</p><p>  此外,其他一些功能缺失,如子查詢和SELECT INTO。但可能是其他主要功能,你會(huì)漏掉回滾/提交的功能。 MySQL不會(huì)執(zhí)行回滾和為某些特殊類型的表提交,但他們并不全是。同樣,MySQL的人提供他們自己的難題為什么MySQL是好的,但能夠回滾事務(wù)是(在我

21、看來(lái))重要以確保您有可用。 </p><p>  回滾可以在開(kāi)始做一系列交易之前在數(shù)據(jù)庫(kù)設(shè)置一個(gè)保存點(diǎn),并能要么回滾到原來(lái)的狀態(tài)或提交在結(jié)束時(shí)候的改變。例如,當(dāng)記錄一次購(gòu)買,你需要記錄一個(gè)針對(duì)用戶的帳戶扣款,并輸入到shipping表記錄,讓你知道后來(lái)ship的項(xiàng)目。比方說(shuō),第二部分失敗。你不會(huì)要收取用戶,但沒(méi)有ship的項(xiàng)目。因此,你要回滾到事務(wù)開(kāi)始之前的狀態(tài)。 </p><p>  因

22、此,MySQL不是一個(gè)成熟的數(shù)據(jù)庫(kù)產(chǎn)品,至少,還不是。它對(duì)于世界上90% 的電子商務(wù)網(wǎng)仍然是相當(dāng)好的,但是,4.0版本在撰寫(xiě)本文時(shí)最初的版本,解決了這些問(wèn)題,包括行級(jí)鎖定和事務(wù)控制數(shù)量。</p><p>  把Tomcat和MySQL的結(jié)合</p><p>  Tomcat和MySQL的結(jié)合為你用它來(lái)學(xué)習(xí)、開(kāi)發(fā)和部署JSP應(yīng)用程序提供了一個(gè)強(qiáng)大的、可靠的和免費(fèi)的平臺(tái)。而且,最好的是,您開(kāi)發(fā)

23、的代碼將使用這個(gè)平臺(tái)很好地運(yùn)行使用iPlanet和Oracle或WebSphere和SQL Server。</p><p>  作為一個(gè)學(xué)習(xí)工具,兩者的結(jié)合幾乎是“參考實(shí)現(xiàn)“他們(JSP和SQL)各自的協(xié)議。因此,當(dāng)你熟悉了解項(xiàng)目的詳細(xì)情況時(shí),你不會(huì)接到任何惡劣的廠商專有的壞習(xí)慣。</p><p>  此外,你可以享受你正在支持開(kāi)源軟件活動(dòng)的知識(shí)。開(kāi)放源碼軟件是根據(jù)多個(gè)公共許可證的編碼,往

24、往是GNU通用公共許可證(GPL)的人免費(fèi)提供。</p><p>  為什么支持這項(xiàng)活動(dòng)是很好的?對(duì)于這個(gè)問(wèn)題的答案有兩點(diǎn):一個(gè)是技術(shù)的和一個(gè)政治的。從技術(shù)上講,這是一件好事,因?yàn)殚_(kāi)源軟件往往鼓勵(lì)如JSP和JDBC開(kāi)放標(biāo)準(zhǔn)的開(kāi)發(fā),讓您從一個(gè)更大的群體里去選擇你的工具,而不是被鎖定成為一個(gè)廠商的專有解決方案。從政治上來(lái)說(shuō)這是一個(gè)積極的事,因?yàn)樗3终紊系拇蠊镜恼\(chéng)實(shí)。 WebLogic和iPlanet必須保持競(jìng)爭(zhēng)

25、力的和響應(yīng),因?yàn)樗麄冎溃幸粋€(gè)免費(fèi)的解決方案在那里,如果他們不這樣。而當(dāng)你使用開(kāi)源軟件,你發(fā)送一條消息,你的首要問(wèn)題是他們的特點(diǎn)和可靠性,如果出現(xiàn)錯(cuò)誤,沒(méi)有一個(gè)大公司提起訴訟。</p><p>  原文出處《MySQL and JSP Web applications 》作者:James Turner</p><p>  MySQL and JSP Web applications<

26、;/p><p>  JSP developers encounter unique problems when building web applications that require intense database connectivity. MySQL and JSP Web Applications addresses the challenges of building data-driven appl

27、ications based on the JavaServer Pages development model. MySQL and JSP Web Applications begins with an overview of the core technologies required for JSP database development--JavaServer Pages, JDBC, and the database sc

28、hema. The book then outlines and presents an Internet commerce application that </p><p>  So What Is JSP All About? </p><p>  If you meet the requirements mentioned, you should already have a pr

29、etty good idea what the answer to this question is. JSP is all about doing highly object-oriented Web sites that can leverage all the best practices of modern software engineering. These practices include things such as

30、SQL databases and UML-based design. This isn't to say that JSP is a cure-all and that using it will automatically make your Web site a paragon of engineering art. It's just as possible to design bad Web sites in

31、</p><p>  JSP grew out of Java servlets. Servlets allow the developer to handle the incoming Web requests using a Java program that has access to all the normal information that a Common Gateway Interface (C

32、GI) program would. In addition, the servlet has access to session-persistent objects. These are Java objects that are associated with a specific user session and can be used to store state between requests. Servlet progr

33、amming was a major step forward in allowing developers to write well-structured mod</p><p>  Out.println("<HTML>\n<HEAD>\n<TITLE>Thank you for </p><p>  Registering</TI

34、TLE></HEAD>\n"); </p><p>  Out.println("<IMG SRC=\"thanks.jpg\" WIDTH=200 HEIGHT=100 ALIGN=\"LEFT\”>"); </p><p>  This kind of embedding gets very ol

35、d very fast when you have to code a lot of pages. In addition, having to escape all of the quotation marks can lead to a lot of confusing and hard-to-find errors if you leave out a backslash. Eventually, a still-better i

36、dea emerged. Suppose that you could combine the best of static HTML pages and with the interactive capabilities of servlets. The result was JavaServer Pages (on the Microsoft side, the result was Active Server Pages). As

37、 Figure I.1 shows, JSP is</p><p>  1. A request comes in from a browser using the normal HTTP request format. </p><p>  2. The Web server hands off the request to JSP. JSP looks at the filename

38、and finds the appropriate JSP file. </p><p>  3. The .jsp file is converted into a .java file, containing Java code that will create a class whose name is derived from the .jsp filename. </p><p>

39、;  4. JSP then compiles the .java file using javac to produce a .class file. Note that the two previous steps are skipped if a .class file already exists and is newer than the .jsp file. </p><p>  5. An inst

40、ance of the newly created class is instantiated and sent the _jspService message. </p><p>  6. The new instance looks to see if there is already an instance of the stuff.User object called user existing in t

41、he session object space for the currently connected user. If not, one is instantiated.</p><p>  7. As part of servicing stuff.jsp, the user instance is called with the getUserName() method. </p><p

42、>  8. If the JSP processing requires access to information in a database, it uses JDBC to make the connection and handle the SQL requests.</p><p>  As you can see, a tremendous amount of power is availabl

43、e in the JSP world. Developers are free to write Web pages that look mostly like HTML, except where callouts to Java are required. But, at the same time, they are free to develop fully fleshed-out object-oriented applica

44、tions using all the features that Java can bring to bear. They also get all the benefits of servlets, including session persistence.</p><p>  Why Do We Need Databases?</p><p>  Well, one reason

45、is so that Larry Ellison of Oracle can afford to keep himself on Prozac when he thinks about Bill Gates. A more serious answer is the same reason that drove man to first press a stick against a piece of wet mud: because

46、it's good to write things down. Web servers are marvelous creatures, but they're a bit like idiot savants. Ask them to serve a Web page or run a piece of Java, and they perform like a champ. But start asking them

47、 to remember what they did five minutes ago, and th</p><p>  The first and most important reason that you use databases is that there's a lot in an e-commerce transaction that you need to remember and tr

48、ack: </p><p>  ?A user's name, address, credit card, and other information previously entered on a registration page </p><p>  ?hat the user might have put into a shopping cart and left from

49、 a previous transaction </p><p>  ?What items are in stock, along with their price, description, and so on </p><p>  ?Orders that need to be fulfilled, orders that have been shipped, and items t

50、hat have been backordered .</p><p>  Now, you could store all this information in a flat file on the server's hard disk, but there are other important properties that you want to have for this data: <

51、/p><p>  ?You want to be able to back out a transaction if part of it fails. </p><p>  ?You want to be able to locate the data somewhere more secure than the Web server, which could be in a DMZ or

52、outside the firewall altogether. </p><p>  ?You want to be able to access data such as user data or products quickly, even if there are thousands or millions of them.</p><p>  When you add these

53、 items to the shopping list, only a relational database will really do the job effectively.</p><p><b>  MySQL </b></p><p>  Many sites don't need the battleship strength (and pri

54、ce tag) of Oracle. MySQL is an open-source SQL database available for anyone to use, with many (although not all) of the features of its big brothers, such as Oracle. </p><p>  MySQL is available for just ab

55、out any computer that has decent power—it is fairly lightweight on the processor and easy to install (10 minutes, as opposed to multiple hours for Oracle). </p><p>  So, perhaps you are wondering, what's

56、 the catch? What are you not getting in MySQL that makes people turn to Oracle? Well, MySQL is a neat little package, but it is missing some things that would be nice to have in a perfect world. </p><p>  A

57、major feature that MySQL does not offer is database consistency checking. You can use foreign key tags in your schema, but MySQL cheerfully ignores them. A lot of DB As I know would consider this a very bad thing.</p&

58、gt;<p>  A foreign key constraint prevents you from creating inconsistent data. For example, let's suppose that you had a scheme that looked like this: </p><p>  CREATE TABLE USER ( </p>&l

59、t;p>  USERID INTEGER, </p><p>  FIRST_NAME VARCHAR(80), </p><p>  LAST_NAME VARCHAR(80)); </p><p>  CREATE TABLE PURCHASE ( </p><p>  USERID FOREIGN KEY USE

60、R(USERID), </p><p>  ITEM INTEGER, </p><p>  QUANTITY INTEGER); </p><p>  In a database such as Oracle's, if you created an entry in the PURCHASE table with a user ID of 3, ther

61、e would have to already be a user ID of 3 in the USER table or an error would occur. Similarly, you couldn't delete user 3 from USER if it was referenced in PURCHASE.The MySQL folks make a pretty impassioned argument

62、 in their documentation that depending on foreign keys for data integrity is a bad idea anyway, but convincing your DBA of this philosophy is likely to degrade into a religious deba</p><p>  In addition, som

63、e other features are missing, such as subselects and select into. But probably the other major piece that you will miss is the rollback/commit functionality. MySQL does implement rollback and commit for certain types of

64、tables, but not all of them. Again, the MySQL folks offer their own spin on why this is okay, but being able to roll back transactions is (in my opinion) important enough to make sure that you have it available. </p&g

65、t;<p>  Rollback allows you to set a savepoint on the database before starting to do a series of transactions with it, and be able to either roll back to the original state or commit the changes at the end. For ex

66、ample, when recording a purchase, you need to record a debit against the user's account and enter a record into the shipping table so that you'll know later to ship the item. Let's say that the second part fa

67、ils. You wouldn't want to charge the user but not ship the item. Thus, you'd want to ro</p><p>  So, MySQL isn't a full-blown production database—at least, not yet. It's still good enough for

68、 probably 90% of the e-commerce sites in the world, however. And version 4.0, which is in alpha as of this writing, addresses a number of these concerns, including row-level locking and transaction control.</p>&l

69、t;p>  Putting Tomcat and MySQL Together</p><p>  Combining Tomcat and MySQL provides a powerful, reliable, and free platform that you can use to learn, develop, and deploy JSP applications. And, best of a

70、ll, the code that you develop using this platform will run nicely using iPlanet and Oracle or WebSphere and SQL Server.</p><p>  As a learning tool the two together are almost "reference implementations

71、" of their respective protocols (JSP and SQL). As a result, you won't pick up any nasty vendor-proprietary bad habits while you're getting up to speed. </p><p>  In addition, you can enjoy the k

72、nowledge that you are supporting the open-source software movement. Open-source software is code that is made freely available under one of several public licenses, frequently the GNU General Public License (GPL).</p&

73、gt;<p>  Why is it good to support this movement? There are two sides to this answer: one technical and one political. Technically, it's a good thing because open-source software tends to encourage the develop

74、ment of open standards such as JSP and JDBC, allowing you to choose your tools from among a larger group rather than being locked into one vendor's proprietary solution. It's a positive thing politically because

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論