SlideShare a Scribd company logo
Submit Search
Upload
Login
Signup
Servlet & JSP 教學手冊第二版 - 第 1 章:簡介Web應用程式
Report
Justin Lin
Follow
Technology / Community Evangelist at Free lancer
Feb. 13, 2013
•
0 likes
•
19,168 views
1
of
53
Servlet & JSP 教學手冊第二版 - 第 1 章:簡介Web應用程式
Feb. 13, 2013
•
0 likes
•
19,168 views
Download Now
Download to read offline
Report
Technology
Servlet & JSP 教學手冊第二版
Justin Lin
Follow
Technology / Community Evangelist at Free lancer
Recommended
Ch05 Servlet 進階 API、過濾器與傾聽器
Justin Lin
200 views
•
69 slides
Ch02 撰寫與設定 Servlet
Justin Lin
337 views
•
37 slides
CH1. 簡介 Web 應用程式
Justin Lin
1.1K views
•
55 slides
Ch06 使用 JSP
Justin Lin
245 views
•
83 slides
Ch13 整合 Spring MVC/Security
Justin Lin
279 views
•
58 slides
Ch03 請求與回應
Justin Lin
230 views
•
73 slides
More Related Content
What's hot
Ch09 整合資料庫
Justin Lin
229 views
•
92 slides
Ch12 Spring 起步走
Justin Lin
265 views
•
31 slides
Ch02 撰寫與設定Servlet
Justin Lin
998 views
•
37 slides
CH1:Java平台概論
Justin Lin
1.2K views
•
41 slides
Spring 2.0 技術手冊第一章 - 認識 Spring
Justin Lin
10K views
•
17 slides
CH04:認識物件
Justin Lin
421 views
•
87 slides
What's hot
(20)
Ch09 整合資料庫
Justin Lin
•
229 views
Ch12 Spring 起步走
Justin Lin
•
265 views
Ch02 撰寫與設定Servlet
Justin Lin
•
998 views
CH1:Java平台概論
Justin Lin
•
1.2K views
Spring 2.0 技術手冊第一章 - 認識 Spring
Justin Lin
•
10K views
CH04:認識物件
Justin Lin
•
421 views
CH12:Lambda
Justin Lin
•
376 views
Ch09 整合資料庫
Justin Lin
•
467 views
Liferay
Krithika Shekhar
•
6.6K views
Spring 2.0 技術手冊第七章 - Spring Web MVC 框架
Justin Lin
•
4.3K views
使用者認證
Shengyou Fan
•
29.5K views
Java Tutorial:Learn Java in 06:00:00
Justin Lin
•
27.5K views
Java SE 8 技術手冊第 9 章 - Collection與Map
Justin Lin
•
4.9K views
Speed up web API with Laravel and Swoole using Docker
Laravel Poland MeetUp
•
2.7K views
스프링보다 중요한 스프링 이야기
Sungchul Park
•
12.8K views
Sug bangalore - headless jss
Anindita Bhattacharya
•
273 views
Spring Web Services: SOAP vs. REST
Sam Brannen
•
22.4K views
CH09:Collection與Map
Justin Lin
•
286 views
REST API 설계
Terry Cho
•
63.2K views
Spring 2.0 技術手冊第二章 - Spring 入門
Justin Lin
•
5K views
Similar to Servlet & JSP 教學手冊第二版 - 第 1 章:簡介Web應用程式
Ch01 簡介Web應用程式
Justin Lin
1.7K views
•
55 slides
Rest与面向资源的web开发
topgeek
1.2K views
•
39 slides
Real World ASP.NET MVC
jeffz
2.7K views
•
32 slides
How to ASP.NET MVC4
Daniel Chou
987 views
•
78 slides
View 與 Blade 樣板引擎
Shengyou Fan
10.1K views
•
40 slides
运维系统开发与Rails 3页面开发实践
Li JianYe
723 views
•
58 slides
Similar to Servlet & JSP 教學手冊第二版 - 第 1 章:簡介Web應用程式
(20)
Ch01 簡介Web應用程式
Justin Lin
•
1.7K views
Rest与面向资源的web开发
topgeek
•
1.2K views
Real World ASP.NET MVC
jeffz
•
2.7K views
How to ASP.NET MVC4
Daniel Chou
•
987 views
View 與 Blade 樣板引擎
Shengyou Fan
•
10.1K views
运维系统开发与Rails 3页面开发实践
Li JianYe
•
723 views
PHP & AppServ
Ht Wang
•
1.8K views
開放原始碼 Ch2.5 app - oss - 3rd party api(ver 1.0)
My own sweet home!
•
336 views
Servlet & JSP 教學手冊第二版 - 第 2 章:撰寫與設定 Servlet
Justin Lin
•
6.1K views
View 與 Blade 樣板引擎
Shengyou Fan
•
7.9K views
View 與 Blade 樣板引擎
Shengyou Fan
•
41.7K views
非常靠谱 Html 5
Tony Deng
•
1.1K views
Html5
cazhfe
•
867 views
使用 Controller
Shengyou Fan
•
34.1K views
《网页设计与制作》第一章:网页制作基础
greentask
•
438 views
Asp.net core v1.0
國昭 張
•
254 views
Asp.net core v1.0
chang kuo-chao
•
103 views
使用 Controller
Shengyou Fan
•
5.5K views
Spring mvc
pepsixp
•
1.2K views
改善 Angular 開發流程:你所不知道的 Schematics 程式碼產生器
Chieh Kai Yang
•
1.7K views
More from Justin Lin
Ch14 簡介 Spring Boot
Justin Lin
861 views
•
22 slides
Ch11 簡介 JavaMail
Justin Lin
155 views
•
8 slides
Ch10 Web 容器安全管理
Justin Lin
152 views
•
30 slides
Ch08 自訂標籤
Justin Lin
131 views
•
54 slides
14. 進階主題
Justin Lin
401 views
•
86 slides
13.並行、平行與非同步
Justin Lin
234 views
•
81 slides
More from Justin Lin
(20)
Ch14 簡介 Spring Boot
Justin Lin
•
861 views
Ch11 簡介 JavaMail
Justin Lin
•
155 views
Ch10 Web 容器安全管理
Justin Lin
•
152 views
Ch08 自訂標籤
Justin Lin
•
131 views
14. 進階主題
Justin Lin
•
401 views
13.並行、平行與非同步
Justin Lin
•
234 views
12. 除錯、測試與效能
Justin Lin
•
148 views
11. 常用內建模組
Justin Lin
•
140 views
10. 資料永續與交換
Justin Lin
•
148 views
9. 資料結構
Justin Lin
•
285 views
8. open() 與 io 模組
Justin Lin
•
243 views
7. 例外處理
Justin Lin
•
114 views
6. 類別的繼承
Justin Lin
•
165 views
5. 從模組到類別
Justin Lin
•
166 views
4. 流程語法與函式
Justin Lin
•
187 views
3.型態與運算子
Justin Lin
•
196 views
1. Python起步走
Justin Lin
•
648 views
2. 從 REPL 到 IDE
Justin Lin
•
232 views
Python 3.9 技術手冊目錄
Justin Lin
•
570 views
CH19:深入模組化
Justin Lin
•
786 views
Recently uploaded
ncuma_SymPy符號運算套件_習題2.pptx
NCU MCL
6 views
•
2 slides
ncuma_函數微分計算.pptx
NCU MCL
27 views
•
5 slides
ncuma_函數畫圖_習題3.pptx
NCU MCL
917 views
•
1 slide
ncuma_邏輯與迴圈.pptx
NCU MCL
101 views
•
25 slides
ncuma_字串.pptx
NCU MCL
33 views
•
19 slides
ncuma_Taylor 多項式.pptx
NCU MCL
21 views
•
6 slides
Recently uploaded
(20)
ncuma_SymPy符號運算套件_習題2.pptx
NCU MCL
•
6 views
ncuma_函數微分計算.pptx
NCU MCL
•
27 views
ncuma_函數畫圖_習題3.pptx
NCU MCL
•
917 views
ncuma_邏輯與迴圈.pptx
NCU MCL
•
101 views
ncuma_字串.pptx
NCU MCL
•
33 views
ncuma_Taylor 多項式.pptx
NCU MCL
•
21 views
初探 Data API Builder:在幾分鐘內將資料庫轉換成 REST 和 GraphQL 不再是夢想
Alan Tsai
•
21 views
ncuma_函數畫圖_習題1.pptx
NCU MCL
•
477 views
ncuma_函數畫圖.pptx
NCU MCL
•
680 views
ncuma_數值求根法.pptx
NCU MCL
•
15 views
ncuma_微分方程式.pptx
NCU MCL
•
6 views
ncuma_牛頓法.pptx
NCU MCL
•
10 views
ncuma_pylab.pptx
NCU MCL
•
276 views
ncuma_極座標畫圖.pptx
NCU MCL
•
6 views
ncuma_串列.pptx
NCU MCL
•
52 views
ncuma_SymPy符號運算套件_習題1.pptx
NCU MCL
•
11 views
ncuma_牛頓法_習題1.pptx
NCU MCL
•
7 views
ncuma_函數微分計算_習題2.pptx
NCU MCL
•
18 views
ncuma_SymPy符號運算套件.pptx
NCU MCL
•
99 views
黃俊毓講師_以黑客精神黑客自己的家鄉.pdf
俊毓 黃
•
26 views
Servlet & JSP 教學手冊第二版 - 第 1 章:簡介Web應用程式
2.
CHAPTER 1 • 簡介Web應用程式
學習目標 • 認識HTTP基本特性 • 了解GET、POST使用時機 • 了解何為URL/URI編碼 • 認識Web容器角色與重要性 • 初步了解Servlet與JSP的關係 • 初步認識MVC/Model 2
3.
Web應用程式基礎知識 • HTML(HyperText Markup
Language) • HTTP(HyperText Transfer Protocol)URL (Uniform Resource Locator) • 文字編碼
4.
Web應用程式 • 客戶端(Client)與伺服端(Server) • 瀏覽器(Browser)與HTTP伺服器
– 瀏覽器請求伺服器上的檔案或資源 – 對本書的主旨來說,伺服器的檔案或資源必須產 生HTML。
5.
關於HTML • 標籤(Tag)的方式來定義文件結構
6.
關於HTML • 瀏覽器依HTML的結構等資訊進行畫面繪製
7.
關於HTML • w3schools
– http://w3schools.com • HTML Tutorial – http://www.w3schools.com/html/default.asp
8.
URL、URN與URI? •
URL:Uniform Resource Locator • URN:Uniform Resource Name • URI:Uniform Resource Identifier • 早期U代表Universal(萬用) • 標準化之後代表著Uniform(統一)
9.
URL • 主要格式 <協議>:<特定協議部份> •
協議(scheme)指定了以何種方式取得資源 – ftp(檔案傳輸協定,File Transfer protocol) – http(超文件傳輸協定,Hypertext Transfer Protocol) – mailto(電子郵件) – file(特定主機檔案名稱)
10.
URL • 特定協議部份的格式 //<使用者>:<密碼>@<主機>:<埠號>/<路徑>
11.
URL • 檔案系統中C:workspace下的jdbc.pdf檔案
file://C:/workspace/jdbc.pdf
12.
URN • 代表某個資源獨一無二的名稱 • 「Servlet
& JSP教學手冊」的國際標準書號 「ISBN 978-986-181-744-6」
13.
URI • URL與URN為URI的子集 –
標準機構如W3C(World Wide Web Consortium) 文件中,多使用URI – 舊習慣使然,程式設計人員口語交談也多見使用 URL 這個舊稱
14.
URL、URI與URN • 歷史演進與標準發佈 –
http://en.wikipedia.org/wiki/Uniform_Resource_Ide ntifier
15.
關於HTTP
16.
關於HTTP • 基於請求(Request)/回應(Response)模型 • 無狀態(Stateless)通訊協定
17.
GET請求 • 向伺服器取得(GET)指定的資源
18.
GET請求 • 可以發送的請求參數長度有限(這個長度依
瀏覽器版本而有所不同) • 太大量資料並不適合用GET方法來進行請求
19.
POST請求 • 請求時發佈(POST)資訊給伺服器
20.
POST請求 • 大量資料的發送都會使用POST方法 • 請求參數移至訊息本體,網址列上也就不會
出現請求參數 • 較敏感的資訊,即使長度不長,通常也會改 用POST的方式發送
21.
GET或POST? • 過長請求參數,應該改用POST • 敏感性或有安全性考量的請求參數,不應使
用GET請求來發送 • 希望可以讓使用者設定書籤,以便日後點選 書籤瀏覽,應該使用GET • 考慮瀏覽器會網址快取(Cache)資料的問題
22.
GET或POST? • GET請求應該用於等冪操作 • POST請求應該用於非等冪操作
23.
GET或POST? • <form>預設會使用GET
24.
URL編碼 • 如果請求參數值本身包括=符號怎麼辦? • URI保留字元
– 「:」、「/」、「?」、「&」、「=」、「@」、 「%」....
25.
URI保留字元 • 要在請求參數上表達URI中的保留字元,必
須在%字元之後以十六進位數值表示方式, 來表示該字元的八個位元數值 – 「:」(00111010 ) %3A – 「/」(00101111 ) %2F
26.
URL編碼 • 使用java.net.URLEncoder類別的靜態
encode()方法作編碼動作使用 • java.net.URLDecoder的靜態decode() 方法作解碼動作
27.
URL與HTTP編碼 • 在URI規範中,空白字元是編碼為%20 • 在HTTP規範中空白是編碼為「+」
28.
中文字元 • URI規範的URL編碼,針對的是字元UTF-8編
碼的八個位元數值 – 林(UTF-8) %E6%9E%97 – 伺服端處理請求參數時,必須使用UTF-8編碼來 取得正確的「林」字元
29.
中文字元 • 在一個BIG5網頁中,若表單使用GET發送
「林」這個中文字 – 林(Big5) %AA%4C – 伺服端處理請求參數時,就必須指定BIG5編碼, 以取得正確的「林」中文字元
30.
動態網頁?靜態網頁?
31.
客戶端程式、伺服端程式
32.
簡介Servlet/JSP • JVM(Java Virtual
Machine)是Java程式唯一 認識的作業系統,其可執行檔為.class檔案 • Web容器(Container)是Servlet/JSP唯一認得 的HTTP伺服器
33.
何謂Web容器 • 對於撰寫Servlet/JSP來說,容器持有物件、負
責物件生命周期與相關服務連結 • 具體層面.... – 容器就是用Java寫的程式,運行於JVM之上 – Servlet會接觸HttpServletRequest、 HttpServletResponse等物件 – HTTP文字性的通訊協定,如何變成Servlet/JSP中 可用的Java物件?
34.
何謂Web容器 • 抽象層面.... –
可將Web容器視為運行Servlet/JSP的HTTP伺服器 • 就如同Java程式僅認得JVM這個作業系統, Servlet/JSP程式也僅認得Web容器這個概念上 的HTTP伺服器
35.
何謂Web容器 • JVM介於Java程式與實體作業系統之間 –
撰寫Java程式必須了解 JVM與應用程式之間如何 互動 • Web容器介於實體HTTP伺服器與Servlet之間 – 撰寫Servlet/JSP也必須知道Web容器如何與 Servlet/JSP互動,如何管理Servlet 等事實 – JSP最後也是轉譯、編譯、載入為Servlet,在容 器的世界中,真正負責請求、回應的是Servlet
36.
請求/回應範例 1. 客戶端(大部份情況下是瀏覽器)對Web伺服器
發出HTTP請求。 2. HTTP伺服器收到HTTP請求,將請求轉由Web容 器處理,Web容器會剖析HTTP請求內容,建立各 種物件(像是HttpServletRequest、 HttpServletResponse、HttpSession等)。 3. Web容器由請求的URL決定要使用哪個Servlet來 處理請求(事先由開發人員定義)。 4. Servlet根據請求物件(HttpServletRequest) 的資訊決定如何處理,透過回應物件 (HttpServletResponse)來建立回應。
37.
請求/回應範例
38.
容器 http://download.oracle.com/javaee/6/tutorial/doc/bnacj.html
39.
Servlet與JSP
40.
Servlet與JSP
43.
Servlet與JSP
44.
關於MVC/Model 2 • 在Servlet程式中夾雜HTML的畫面輸出絕對
不是什麼好主意 • 在JSP網頁中的HTML間夾雜Java程式碼,也 是極度不建議的作法
45.
MVC • Model、View、Controller • 模型、視圖、控制器
46.
MVC • 模型不會有畫面相關的程式碼 • 視圖負責畫面相關邏輯 •
控制器知道某個操作必須呼叫哪些模型
47.
Model 2 • 套用在Web應用程式的設計上
– 視圖部份可由網頁來實現 – 伺服器上的資料存取或商務邏輯(Business logic) 由模型負責 – 控制器接送瀏覽器的請求,決定呼叫哪些模型來 處理
48.
Model 2 • Web應用程式是基於HTTP,必須基於請求/
回應模型
49.
Model 2 • 控制器(Controller)
– 取得請求參數、驗證請求參數、轉發請求給模型、 轉發請求給畫面,這些都使用程式碼來實現 • 模型(Model) – 接受控制器的請求呼叫,負責處理商務邏輯、負 責資料存取邏輯等,這部份還可依應用程式功能, 產生各多種不同職責的模型物件,模型使用程式 碼來實現
50.
Model 2 • 視圖(View)
– 接受控制器的請求呼叫,會從模型提取運算後的 結果,根據需求呈現所需的畫面,在職責分配良 好的情況下,基本上可作到不出現程式碼,因此 不會發生程式碼與HTML混雜在一起的情況
51.
Model 2
52.
簡介Java EE • JCP、JSR
– Java SE – Java ME – Java EE
53.
簡介Java EE • Java
EE 6平台的主要規範是在JSR 316文件 – http://www.oracle.com/technetwork/java/javaee/tech /index.html • Servlet 3.0規範在JSR 315 • JSP 2.2/EL 2.2規範在JSR 245