Web開發基礎知識
web
web資源
針對Java而言,web資源有:
- html:靜態資源,瀏覽器可以直接看懂
- JSP/servlet:動態資源(可以有變數),需要先轉換為html,再給瀏覽器看
注意
:瀏覽器只認識靜態資源
javaweb三層架構—採用了MVC
從MVC之後,發現此架構適合java
- web層
和web相關的內容(Servlet,JSP) - 業務層
業務物件(Service),對資料庫的零散操作的集合,形成一個功能。 - 資料層
操作資料庫(DAO,Data Access Objects)(所有對資料庫的操作,不能跳出到DAO之外)
原來MVC模型:
web伺服器(軟體伺服器)
web伺服器的作用是接收客戶端的請求,給客戶端做出響應。而不會主動傳送資訊。
Tomcat
當前應用最廣泛的JavaWeb伺服器
(支援JSP/Servlet容器
),不支援EJB容器,所以不支援JavaEE全部功能。
開源免費,由於Sun公司參與了Tomcat的開發,所以最新的JSP/Servlet規範總是能在Tomcat中體現出來。
web.xml
作用
web.xml檔案是用來配置:歡迎頁、servlet、filter等的。
當你的web工程沒用到這些時,你可以不用web.xml檔案來配置你的web工程。
標籤介紹
web.xml的模式檔案是由Sun公司定義的,web.xml的模式(Schema)檔案中定義了多少種標籤元素,web.xml中就可以出現它的模式檔案所定義的標籤元素,它就能擁有定義出來的那些功能。下面列舉一些常用功能:
- <web-app>: 每個web.xml檔案的根元素中,都必須標明這個web.xml使用的是哪個模式檔案。
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" >
</web-app>
- 指定歡迎頁面:<welcome-file-list>
<welcome-file-list>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index1.jsp</welcome-file>
</welcome-file-list>
上面的例子指定了2個歡迎頁面,顯示時按順序從第一個找起,如果第一個存在,就顯示第一個,後面的不起作用。如果第一個不存在,就找第二個,以此類推。
- 歡迎頁面
訪問一個網站時,預設看到的第一個頁面就叫歡迎頁,一般情況下是由首頁來充當歡迎頁的。
當你只指定一個web的根名,沒有指定具體頁面,去訪問時一個web時, 如果web.xml檔案中配置了歡迎頁,那麼就返回指定的那個頁面作為歡迎頁,而在文中沒有web.xml檔案,或雖然有web.xml,但web.xml也沒指定歡迎頁的情況下,那麼不同的應用伺服器可能會有不同的行為,對於tomcat來說,它預設先查詢index.html檔案,如果找到了,就把index.html作為歡迎頁還回給瀏覽器。如果沒找到index.html,tomcat就去找index.jsp。找到index.jsp就把它作為歡迎頁面返回。而如果index.html和index.jsp都沒找到,又沒有用web.xml檔案指定歡迎頁面,那此時tomcat就不知道該返回哪個檔案了,它就顯示The requested resource (/XXX) is not available的頁面。其中XXX表示web的根名。
-
命名與定製URL
可以為Servlet和JSP檔案命名並定製URL,其中定製URL是依賴一命名的,命名必須在定製URL前。下面拿serlet來舉例:(1)為Servlet命名 <servlet> <servlet-name>servlet1</servlet-name> <servlet-class>net.test.TestServlet</servlet-class> </servlet> (2)為Servlet定製URL <servlet-mapping> <servlet-name>servlet1</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping>
-
定製初始化引數
可以定製servlet、JSP、Context的初始化引數,然後可以再servlet、JSP、Context中獲取這些引數值。下面拿servlet來舉例:<servlet> <servlet-name>servlet1</servlet-name> <servlet-class>net.test.TestServlet</servlet-class> <init-param> <param-name>userName</param-name> <param-value>Tommy</param-value> </init-param> <init-param> <param-name>E-mail</param-name> <param-value>[email protected]</param-value> </init-param> </servlet>
-
指定錯誤處理頁面
可以通過“異常型別”或“錯誤碼”來指定錯誤處理頁面<error-page> <error-code>404</error-code> <location>/error404.jsp</location> <error-page> ----------------------------- <error-page> <exception-type>java.lang.Exception<exception-type> <location>/exception.jsp<location> <error-page>
-
設定過濾器
-
設定監聽器
-
設定會話(Session)過期時間
DispatcherServlet
-
DispatcherServlet作用
DispatcherServlet是前端控制器
設計模式的實現,配置在web.xml
檔案中,是配置spring MVC的第一步。
其主要作用是攔截匹配
的請求(攔截匹配規則要自己定義
),把攔截下來的請求,依據相應的規則分發到目標Controller
來處理,從而實現職責排程和流程控制功能。其功能具體而言:
1、檔案上傳解析,如果請求型別是multipart將通過MultipartResolver進行檔案上傳解析;
2、通過HandlerMapping,將請求對映到處理器(返回一個HandlerExecutionChain,它包括一個處理器、多個HandlerInterceptor攔截器);
3、通過HandlerAdapter支援多種型別的處理器(HandlerExecutionChain中的處理器);
4、通過ViewResolver解析邏輯檢視名到具體檢視實現;
5、本地化解析;
6、渲染具體的檢視等;
7、如果執行過程中遇到異常將交給HandlerExceptionResolver來解析。 -
在xml上的配置
<servlet> <servlet-name>chapter2</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>chapter2</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
參考文獻
相關推薦
Web開發基礎知識
web web資源 針對Java而言,web資源有: html:靜態資源,瀏覽器可以直接看懂 JSP/servlet:動態資源(可以有變數),需要先轉換為html,再給瀏覽器看 注意:瀏覽器只認識靜態資源 javaweb三層架構—採用了MVC 從MVC之後
Web開發基礎知識的整理(一、Http協議的簡單介紹)
Web方面的東西,實際上挺多挺雜的,所以有的時候就需要一些整理,今天這裡來簡單介紹一下Http協議,算是對之前學習一些東西的整體,希望對自己或者對一些人有些幫助。 首先從Http協議說起,Web瀏
微信小程序開發基礎知識總結
nodes owa wim remove ide rdd custom value onload 微信小程序在無論在功能、文檔及相關支持方面,都是優於前面幾種微信賬號類型,它提供了很多原生程序才有的接口,使得我們的小程序在很多方面突破H5頁面應用的限制,更加接近原生程序的功
移動web的基礎知識
彈性布局 初始 port 彈性 content max 1.0 計算 box 一、像素 px:CSS pixels邏輯像素,瀏覽器使用的抽象單位 dp,pt:設備無關像素 (物理像素) dpr:設備像素縮放比 計算公式: 1px =
響應式布局的開發基礎知識
是什麽 代碼 開發人員 通過 css3 相對 智能 nta 成了 本章主要分為以下幾個部分 正確理解響應式設計 響應式設計的步驟 響應式設計需要註意的問題 響應式網頁布局實現原理 第一:正確理解響應式布局 響應式網頁設計就是一個網站能夠兼容多個終端-而不是為每個終端做一
web相關基礎知識
賬戶 這一 幫助 cin com 管理 fff 下載 table 2017-12-13 09:47:11 關於HTML 1.絕對路徑和相對路徑 相對路徑:相對於文件自身為參考。 (工作中一般是使用相對路徑) 這裏我們用html文件為參考。如果說ht
學習日記 | 5.29 [Python3] Python Web開發基礎
odi 編碼 AC htm extends app render www amp 註:這是一系列基於實驗樓網絡培訓的python學習日記,內容零散,只是便於我自己回顧,有需要請了解www.shiyanlou.com。 3. 實驗13: jinja2模板 flask
WEB開發基礎
web開發 .cn edi .com html文檔 tid nbsp html www. 添加新隨筆 編輯本目錄 HTML文檔結構 編輯WEB開發基礎
APP開發基礎知識
百度 ips undefine 蘋果官方文檔 java obj .net 屬於 引擎 本文針對小白用戶對App做一個簡單的介紹,首先要了解App都有哪些類型,不同的類型適用於哪些需求,用戶可以根據自己的需求選擇不同的App開發。 一 App有哪些形式 WebApp:簡單來說
第五模塊:WEB開發基礎 第3章·BootStrap&JQuery開發
btn class 彈出 bsp window 右下角 val nload 定義 01-JQuery介紹 02-jQuery文件引入和加載的區別 03-jQuery的基礎選擇器 04-jQuery的層級選擇器 05-jQuery的基本過濾選擇器 06-jQue
java 測試開發基礎知識(類加載,JVM等)
常量表達式 對數 前端 .cn 都是 新的 ron 技術分享 區域 寫在開頭: 面試的時候別人很可能會問你的java原理,.class load 原理, jvm機制,這些都是Java的底層知識,特整理如下: 1. 首先,編寫一個java程序,大家會用ide編寫一個例
Python開發 基礎知識 3.類別&方法 (bool & str) (未完待續)
類別 可使用type()檢視 內建 [ 布林:bool (Boolen) 字串:str (String) 數字:int (Integer) 小數:float 列表:list 元祖:tuple 字典:dict ] 亦可用class宣告新類別 布林值 (用於比較、邏輯
Python開發 基礎知識 2.變量 ( *arg, **kwargs )
python開發 nbsp brush 若有 return pri bsp true justin 變量 *args 和 **kwargs ( *和**為本體,名稱為通俗的名稱約定 ) *args 用於函式定義。 可將不定數量的參數傳遞給一個函數,傳入函式的引數,會先以
python 爬蟲開發基礎知識
Request請求方式 常用的有get post請求的url 第一部分是協議(或稱為服務方式)第二部分是存有該資源的主機IP地址(有時也包括埠號)第三部分是主機資源的具體地址,如目錄和檔名等請求頭 包含請求時的頭部資訊,如User-Agent,Host,Cookies等資訊請求體 請求時攜帶的資料,如提
fiddler二次開發基礎知識
一、官方開發文件 連線在這:http://www.telerik.com/fiddler 開發文件在這:http://docs.telerik.com/fiddler/Extend-Fiddler/ExtendWithDotNet 二、Fiddler介面 Fiddler4 公開介面有以下
區塊鏈開發基礎知識學習
隨著區塊鏈的火熱相信很多同學已經躍躍欲試想投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文就基於以太坊平臺,輕鬆帶大家入區塊鏈技術開發應用的大門。 以太坊是什麼 我們要開發一個區塊鏈應用,如果要從頭開發一個區塊鏈是不現實的,這時我們就需要以太坊這樣的平臺。 以太坊(Ethe
Python web程式設計 基礎知識及其舉例
web程式設計基礎知識 HTML基礎格式 CSS基礎格式 理解HTML和CSS之間的關係 如何開啟電腦開發者工具 如何找到HTML對應的網頁的感興趣的資訊 Python例項1: Python例項2: 附錄說明:
Revit二次開發基礎知識
獲取應用、文件及當前檢視資訊 public Result Execute(ExternalCommandData commandData, ref string message, ElementSet elements) {
Atitit web 之道 艾龍著 Atitit web 之道 艾龍艾提拉著v2 saa.docx 1. 第1章 Web程式設計基礎知識 (1) 3 1.1. 1.1 什麼是Web (1) 3 1.2.
Atitit web 之道 艾龍著 Atitit web 之道 艾龍艾提拉著v2 saa.docx 1. 第1章 Web程式設計基礎知識 (1) 3 1.1. 1.1 什麼是Web (1) 3 1.2. 1.2 Web的工作原理 (2) 3 1.3. 1.3 Int
Linux驅動開發基礎知識
常用命令 lsmod: list module,將模組列表顯示),功能是打印出當前核心中已經安裝的模組列表 insmod: install module,安裝模組,功能是向當前核心中去安裝一個模組,用法是insmod xxx.ko modinfo: module information,模組資