国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java面試題 Java Web常見面試題

Java Web常見面試題

Jan 08, 2020 pm 03:39 PM
java

Java Web常見面試題

jsp 和 servlet 有什麼不同? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?中上建立「建議學(xué)習(xí):java常見的面試題#)

jsp經(jīng)編譯後就變成了Servlet.java常見的面試題

)

##jsp經(jīng)典,本質(zhì)上變成了Servlet.(JjavaSP的Servlet.辨識JSP的程式碼,Web容器將JSP的程式碼編譯成JVM能夠辨識的java類別)

jsp更擅長表現(xiàn)於頁面顯示,servlet更擅長於邏輯控制。

Servlet中沒有內(nèi)建對象,Jsp中的內(nèi)建物件都是必須透過HttpServletRequest對象,HttpServletResponse物件以及HttpServlet物件得到。

Jsp是Servlet的一種簡化,使用Jsp只需要完成程式設(shè)計師需要輸出到客戶端的內(nèi)容,Jsp中的Java腳本如何鑲嵌到一個類別中,由Jsp容器完成。而Servlet則是個完整的Java類,這個類別的Service方法用來產(chǎn)生對客戶端的回應(yīng)。

jsp 有哪些內(nèi)建物件?作用分別是什麼?

JSP有9個內(nèi)建物件:

request:封裝客戶端的請求,其中包含來自GET或POST請求的參數(shù);

response:封裝伺服器對客戶端的回應(yīng);

pageContext:透過該物件可以取得其他物件;

session:封裝使用者會話的物件;

application:封裝伺服器運行環(huán)境的物件;

out:輸出伺服器回應(yīng)的輸出流物件;

config:Web應(yīng)用的設(shè)定物件;

page:JSP頁面本身(相當(dāng)於Java程式中的this);

exception:封裝頁面拋出例外的物件。

說一下 jsp 的 4 種作用域?

JSP中的四個作用域包括page、request、session和application,具體來說:

page代表與一個頁面相關(guān)的物件和屬性。

request代表與Web客戶機發(fā)出的一個請求相關(guān)的物件和屬性。一個請求可能跨越多個頁面,涉及多個Web元件;需要在頁面顯示的臨時資料可以置於此作用域。

session代表與某個使用者與伺服器建立的一次會話相關(guān)的物件和屬性。跟某個使用者相關(guān)的資料應(yīng)該放在使用者自己的session中。

application代表與整個Web應(yīng)用程式相關(guān)的物件和屬性,它實質(zhì)上是跨越整個Web應(yīng)用程序,包括多個頁面、請求和會話的一個全域作用域。

session 和 cookie 有什麼不同?

由於HTTP協(xié)定是無狀態(tài)的協(xié)議,所以當(dāng)服務(wù)端需要記錄用戶的狀態(tài)時,就需要用某種機制來識具體的用戶,這個機制就是Session.典型的場景例如購物車,當(dāng)你點擊下單按鈕時,由於HTTP協(xié)議無狀態(tài),所以並不知道是哪個用戶操作的,所以服務(wù)端要為特定的用戶創(chuàng)建了特定的Session,用用於標(biāo)識這個用戶,並且跟蹤用戶,這樣才知道購物車裡面有幾本書。

這個Session是保存在服務(wù)端的,有一個唯一識別。在服務(wù)端保存Session的方法很多,記憶體、資料庫、檔案都有。

集群的時候也要考慮Session的轉(zhuǎn)移,在大型的網(wǎng)站,一般會有專門的Session伺服器集群,用來保存用戶會話,這個時候Session 信息都是放在內(nèi)存的,使用一些緩存服務(wù)例如Memcached之類的來放Session。

思考一下服務(wù)端如何辨識特定的客戶?

這時候Cookie就登場了。每次HTTP請求的時候,客戶端都會傳送對應(yīng)的Cookie訊息到服務(wù)端。實際上大多數(shù)的應(yīng)用程式都是用Cookie 來實作Session追蹤的,第一次建立Session的時候,服務(wù)端會在HTTP協(xié)定中告訴客戶端,需要在Cookie 裡面記錄一個Session ID,以後每次要求把這個會話ID傳送到伺服器,我就知道你是誰了。

有人問,如果客戶端的瀏覽器停用了 Cookie 怎麼辦?

一般這種情況下,會使用一種稱為URL重寫的技術(shù)來進行會話跟蹤,即每次HTTP交互,URL後面都會被附加上一個諸如sid=xxxxx 這樣的參數(shù),服務(wù)端據(jù)此來辨識使用者。

Cookie其實還可以用在一些方便使用者的場景下,設(shè)想你某次登陸過一個網(wǎng)站,下次登入的時候不想再輸入帳號了,怎麼辦?

這個訊息可以寫到Cookie裡面,造訪網(wǎng)站的時候,網(wǎng)站頁面的腳本可以讀取這個訊息,就自動幫你把使用者名稱填入了,能夠方便一下使用者。這也是Cookie名稱的由來,給使用者的一點甜頭。

所以,總結(jié)一下:

###Session是在服務(wù)端保存的資料結(jié)構(gòu),用來追蹤使用者的狀態(tài),這個資料可以保存在叢集、資料庫、文件中;###

Cookie是客戶端保存使用者資訊的一種機制,用來記錄使用者的一些訊息,也是實現(xiàn)Session的一種方式。

說一下 session 的工作原理?

其實session是一個存在伺服器上的類似一個散列表格的檔案。裡面存有我們需要的訊息,在我們需要用的時候可以從裡面取出。

類似一個大號的map吧,裡面的鍵存儲的是用戶的sessionid,用戶向伺服器發(fā)送請求的時候會帶上這個sessionid。這時就可以從中取出對應(yīng)的數(shù)值了。

如果客戶端禁止 cookie 能實現(xiàn) session 還能用嗎?

Cookie與 Session,一般認(rèn)為是兩個獨立的東西,Session採用的是在伺服器端保持狀態(tài)的方案,而Cookie採用的是在客戶端保持狀態(tài)的方案。

但為什麼停用Cookie就不能得到Session呢?

因為Session是用Session ID來確定目前對話所對應(yīng)的伺服器Session,而Session ID是透過Cookie來傳遞的,禁用Cookie相當(dāng)於失去了Session ID,也就不會得到Session了。

假設(shè)使用者在關(guān)閉Cookie的情況下使用Session,其實作途徑有以下幾種:

設(shè)定php.ini設(shè)定檔中的「session.use_trans_sid = 1 ”,或編譯時開啟了“--enable-trans-sid”選項,讓PHP自動跨頁傳遞Session ID。

手動透過URL傳值、隱藏表單傳遞Session ID。

用檔案、資料庫等形式保存Session ID,在跨頁過程中手動呼叫。

spring mvc 和 struts 的差別是什麼?

攔截機制的不同

Struts2是類別層級的攔截,每次要求就會建立一個Action,和Spring整合時Struts2的ActionBean注入作用域是原型模式prototype,然後透過setter,getter吧request資料注入到屬性。

Struts2中,一個Action對應(yīng)一個request,response上下文,在接收參數(shù)時,可以透過屬性接收,這表示屬性參數(shù)是讓多個方法共享的。

Struts2中Action的一個方法可以對應(yīng)一個url,而其類別屬性卻被所有方法共享,這也就無法用註解或其他方式標(biāo)識其所屬方法了,只能設(shè)計為多例。

SpringMVC是方法層級的攔截,一個方法對應(yīng)一個Request上下文,所以方法直接基本上是獨立的,獨享request,response資料。而每個方法同時又何一個url對應(yīng),參數(shù)的傳遞是直接注入到方法中的,是方法所獨有的。處理結(jié)果透過ModeMap傳回給框架。

在Spring整合時,SpringMVC的Controller Bean預(yù)設(shè)單例模式Singleton,所以預(yù)設(shè)對所有的請求,只會創(chuàng)建一個Controller,有應(yīng)為沒有共享的屬性,所以是線程安全的,如果要改變預(yù)設(shè)的作用域,需要加入@Scope註解修改。

Struts2有自己的攔截Interceptor機制,SpringMVC這是用的是獨立的Aop方式,這樣導(dǎo)致Struts2的設(shè)定檔量還是比SpringMVC大。

底層框架的不同

Struts2採用Filter(StrutsPrepareAndExecuteFilter)實現(xiàn),SpringMVC(DispatcherServlet)則採用Servlet實作。 Filter在容器啟動之後即初始化;服務(wù)停止以後墜毀,晚於Servlet。 Servlet在呼叫時初始化,先於Filter調(diào)用,服務(wù)停止後銷毀。

效能方面

Struts2是類別層級的攔截,每次要求對應(yīng)實例一個新的Action,需要載入所有的屬性值注入,SpringMVC實作了零配置,由於SpringMVC基於方法的攔截,因此有加載一次單例模式bean注入。所以,SpringMVC開發(fā)效率和效能高於Struts2。

配置方面

spring MVC和Spring是無縫的。從這個專案的管理和安全上也比Struts2高。

如何避免 sql 注入?

PreparedStatement(簡單又有效的方法)

使用正規(guī)表示式過濾傳入的參數(shù)

字串過濾

JSP中調(diào)用函數(shù)檢查是否包函非法字元

JSP頁面判斷程式碼

什麼是XSS 攻擊,如何避免?

XSS攻擊又稱CSS,全名為Cross Site Script? (跨站腳本攻擊),其原理是攻擊者向有XSS漏洞的網(wǎng)站中輸入惡意的HTML 程式碼,當(dāng)使用者瀏覽網(wǎng)站時,這段HTML 程式碼會自動執(zhí)行,達到攻擊的目的。

XSS 攻擊類似於SQL 注入攻擊,SQL注入攻擊中以SQL語句作為用戶輸入,達到查詢/修改/刪除資料的目的,而在xss攻擊中,透過插入惡意腳本,實現(xiàn)對用戶遊覽器的控制,取得使用者的一些資訊。 XSS是 Web 程式中常見的漏洞,XSS 屬於被動式且用於客戶端的攻擊方式。

XSS防範(fàn)的整體思路是:對輸入(和URL參數(shù))進行過濾,對輸出進行編碼。

什麼是 CSRF 攻擊,如何避免?

CSRF(Cross-site request forgery)也被稱為 one-click attack或 session riding,中文全稱是叫跨站請求偽造。一般來說,攻擊者透過偽造用戶的瀏覽器的請求,向訪問一個用戶自己曾經(jīng)認(rèn)證訪問過的網(wǎng)站發(fā)送出去,使目標(biāo)網(wǎng)站接收並誤以為是用戶的真實操作而去執(zhí)行命令。

常用於盜取帳號、轉(zhuǎn)帳、發(fā)送假訊息等。攻擊者利用網(wǎng)站對請求的驗證漏洞而實現(xiàn)這樣的攻擊行為,網(wǎng)站能夠確認(rèn)請求來自使用者的瀏覽器,卻無法驗證請求是否源自於使用者的真實意願下的操作行為。

如何避免:

1.驗證HTTP Referer 欄位

HTTP頭中的Referer欄位記錄了該HTTP 請求的來源位址。在通常情況下,訪問一個安全受限頁面的請求來自於同一個網(wǎng)站,而如果駭客要對其實施 CSRF

#攻擊,他一般只能在他自己的網(wǎng)站建構(gòu)請求。因此,可以透過驗證Referer值來防禦CSRF 攻擊。

2. 使用驗證碼

關(guān)鍵操作頁面加上驗證碼,後臺收到請求後透過判斷驗證碼可以防禦CSRF。但這種方法對使用者不太友善。

3. 在請求位址中新增token並驗證

CSRF 攻擊之所以能夠成功,是因為駭客可以完全偽造使用者的請求,該請求中所有的使用者驗證資訊都是存在於cookie中,因此駭客可以在不知道這些驗證資訊的情況下直接利用使用者自己的cookie 來通過安全驗證。要抵禦 CSRF,關(guān)鍵在於在請求中放入駭客所不能偽造的信息,並且該信息不存在於 cookie 之中。

可以在HTTP 請求中以參數(shù)的形式加入一個隨機產(chǎn)生的token,並在伺服器端建立一個攔截器來驗證這個token,如果請求中沒有token或token 內(nèi)容不正確,則認(rèn)為可能是CSRF 攻擊而拒絕該請求。

這種方法要比檢查Referer 要安全一些,token 可以在用戶登陸後產(chǎn)生並放於session之中,然後在每次請求時把token 從session 中拿出,與請求中的token進行比對,但這種方法的困難在於如何把token 以參數(shù)的形式加入請求。

對於 GET 要求,token 會附在請求位址之後,這樣 URL 就會變成 http://url?csrftoken=tokenvalue。

而對於POST 請求來說,要在form 的最後加上,這樣就把token以參數(shù)的形式加入請求了。

4. 在HTTP 頭中自訂屬性並驗證

這種方法也是使用token 並進行驗證,和上一個方法不同的是,這裡並不是把token 以參數(shù)的形式置於HTTP 請求之中,而是把它放到HTTP 頭中自訂的屬性裡。

透過 XMLHttpRequest 這個類,可以一次給所有該類請求加上 csrftoken 這個 HTTP 頭屬性,並把 token 值放入其中。

這樣解決了上種方法在請求中加入token 的不便,同時,透過XMLHttpRequest 請求的位址不會被記錄到瀏覽器的位址欄,也不用擔(dān)心token 會透過Referer 洩漏到其他網(wǎng)站中去。

以上是Java Web常見面試題的詳細內(nèi)容。更多資訊請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時獲取鍵和值,適用於大多數(shù)場景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結(jié)構(gòu)。 entrySet返回包含所有鍵值對的Set集合,每次循環(huán)獲取Map.Entry對象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調(diào)用keySet()或values(),也可在遍歷鍵時通過map.get(key)獲取值;Java8中可通過Lambda表達式使用forEach((key,value)-&gt

Java可選示例 Java可選示例 Jul 12, 2025 am 02:55 AM

Optional能清晰表達意圖並減少null判斷的代碼噪音。 1.Optional.ofNullable是處理可能為null對象的常用方式,如從map中取值時可結(jié)合orElse提供默認(rèn)值,邏輯更清晰簡潔;2.通過鍊式調(diào)用map實現(xiàn)嵌套取值,安全地避免NPE,任一環(huán)節(jié)為null則自動終止並返回默認(rèn)值;3.filter可用於條件篩選,滿足條件才繼續(xù)執(zhí)行後續(xù)操作,否則直接跳到o??rElse,適合輕量級業(yè)務(wù)判斷;4.不建議過度使用Optional,如基本類型或簡單邏輯中其反而增加複雜度,部分場景直接返回nu

如何修復(fù)java.io.notserializable Exception? 如何修復(fù)java.io.notserializable Exception? Jul 12, 2025 am 03:07 AM

遇到j(luò)ava.io.NotSerializableException的核心解決方法是確保所有需序列化的類實現(xiàn)Serializable接口,並檢查嵌套對象的序列化支持。 1.給主類添加implementsSerializable;2.確保類中自定義字段對應(yīng)的類也實現(xiàn)Serializable;3.用transient標(biāo)記不需要序列化的字段;4.檢查集合或嵌套對像中的非序列化類型;5.查看異常信息定位具體哪個類未實現(xiàn)接口;6.對無法修改的類考慮替換設(shè)計,如保存關(guān)鍵數(shù)據(jù)或使用可序列化的中間結(jié)構(gòu);7.考慮改

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用於類內(nèi)部定義默認(rèn)排序規(guī)則,Comparator用於外部靈活定義多種排序邏輯。 1.Comparable是類自身實現(xiàn)的接口,通過重寫compareTo()方法定義自然順序,適用於類有固定、最常用的排序方式,如String或Integer。 2.Comparator是外部定義的函數(shù)式接口,通過compare()方法實現(xiàn),適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在於Comparable只能定義一種排序邏輯且需修改類本身,而Compar

如何處理Java中的字符編碼問題? 如何處理Java中的字符編碼問題? Jul 13, 2025 am 02:46 AM

處理Java中的字符編碼問題,關(guān)鍵是在每一步都明確指定使用的編碼。 1.讀寫文本時始終指定編碼,使用InputStreamReader和OutputStreamWriter並傳入明確的字符集,避免依賴系統(tǒng)默認(rèn)編碼。 2.在網(wǎng)絡(luò)邊界處理字符串時確保兩端一致,設(shè)置正確的Content-Type頭並用庫顯式指定編碼。 3.謹(jǐn)慎使用String.getBytes()和newString(byte[]),應(yīng)始終手動指定StandardCharsets.UTF_8以避免平臺差異導(dǎo)致的數(shù)據(jù)損壞??傊?,通過在每個階段

如何在Java解析JSON? 如何在Java解析JSON? Jul 11, 2025 am 02:18 AM

解析JSON在Java中的常見方式有三種:使用Jackson、Gson或org.json。 1.Jackson適合大多數(shù)項目,性能好且功能全面,支持對象與JSON字符串之間的轉(zhuǎn)換及註解映射;2.Gson更適合Android項目或輕量級需求,使用簡單但處理複雜結(jié)構(gòu)和高性能場景略遜;3.org.json適用於簡單任務(wù)或小腳本,不推薦用於大型項目,因其靈活性和類型安全不足。選擇應(yīng)根據(jù)實際需求決定。

Java方法參考解釋了 Java方法參考解釋了 Jul 12, 2025 am 02:59 AM

方法引用是Java中一種簡化Lambda表達式的寫法,使代碼更簡潔。它不是新語法,而是Java8引入的Lambda表達式的一種快捷方式,適用於函數(shù)式接口的上下文。其核心在於將已有方法直接作為函數(shù)式接口的實現(xiàn)來使用。例如System.out::println等價於s->System.out.println(s)。方法引用主要有四種形式:1.靜態(tài)方法引用(ClassName::staticMethodName);2.實例方法引用(綁定到特定對象,instance::methodName);3.

新電子郵件的Outlook快捷方式 新電子郵件的Outlook快捷方式 Jul 11, 2025 am 03:25 AM

在Outlook中快速新建郵件的方法如下:1.桌面版使用快捷鍵Ctrl Shift M,可直接彈出新郵件窗口;2.網(wǎng)頁版可通過創(chuàng)建包含JavaScript的書籤(如javascript:document.querySelector("divrole='button'").click())實現(xiàn)一鍵新建郵件;3.使用瀏覽器插件(如Vimium、CrxMouseGestures)自定義快捷鍵觸發(fā)“新建郵件”按鈕;4.Windows用戶還可通過右鍵任務(wù)欄Outlook圖標(biāo)選擇“新建電

See all articles