前后臺交互的學(xué)習(xí)(Java web)

標(biāo)簽:前后端交互Javaweb

下面介紹了一些關(guān)于交互的細(xì)節(jié):

1.請求數(shù)據(jù)

  • 前端提供請求數(shù)據(jù)测秸。

     在開發(fā)中,后臺在查詢數(shù)據(jù)庫時(shí),需要借助查詢條件才能查詢到前端需要的數(shù)據(jù),而查詢條件正是此時(shí)前端提供相關(guān)的查詢參數(shù)(即URL請求的參數(shù))
    

2.接口文檔

  • 接口文檔主要由后臺設(shè)計(jì)和修改霎冯。

      后臺直接跟數(shù)據(jù)打交道铃拇,最熟悉數(shù)據(jù)庫。前端只是數(shù)據(jù)的接受者和接口文檔的使用者沈撞。
    

3.交互數(shù)據(jù)的格式

  • 主要是JSON慷荔,以及不常用的XML。

      JSON通常用于與服務(wù)器交換數(shù)據(jù)缠俺,AJAX也是通過JSON數(shù)據(jù)來完成交互显晶。
    

4.交互的原理

  • 前端根據(jù)接口,提供請求參數(shù)壹士,后臺接收參數(shù)磷雇,根據(jù)參數(shù)查詢數(shù)據(jù)庫,并得到返回的數(shù)據(jù)躏救,將返回的參數(shù)送到前端唯笙。前端調(diào)用接口,將返回的數(shù)據(jù)呈現(xiàn)落剪。

5.請求方法

  • 請求方法主要有POST和GET睁本,GET是向服務(wù)器發(fā)索取數(shù)據(jù)的一種請求,而POST是向服務(wù)器提交數(shù)據(jù)(提交表單)的一種請求忠怖。

下面以Java web講述前后端的交互方式:

1.利用cookie對象

Cookie是服務(wù)器保存在客戶端中的一小段數(shù)據(jù)信息呢堰。使用Cookie有一個(gè)前提,就是客戶端瀏覽器允許使用Cookie并對此做出相應(yīng)的設(shè)置凡泣。一般不贊成使用Cookie坊秸。
????(1)后臺代碼

Cookie cookie=new Cookie("name", "hello");  
response.addCookie(cookie);  

????(2)前臺代碼

Cookie[] cookies=request.getCookies(); 
for(int i=0;i<cookies.length;i++){ 
    if(cookies[i].getName().toString().equals("name")){ 
        out.print(cookies[i].getValue()); 
    } 
}

2. 利用session對象

session對象表示特定會(huì)話session的用戶數(shù)據(jù)现喳‰食冢客戶第一次訪問支持session的JSP網(wǎng)頁蚌父,服務(wù)器會(huì)創(chuàng)建一個(gè)session對象記錄客戶的信息。當(dāng)客戶訪問同一網(wǎng)站的不同網(wǎng)頁時(shí)贺纲,仍處于同一個(gè)session中航闺。
????(1)后臺代碼

request.getSession().setAttribute("name", name);
request.getSession().setMaxInactiveInterval(2); 
response.sendRedirect("welcome.jsp");

????(2)前臺代碼(jsp頁面)

Object user=request.getSession().getAttribute("name");

3. 利用request重定向,設(shè)置setAttribute

????(1)后臺代碼

request.setAttribute("name", "cute");  
request.getRequestDispatcher("welcome.jsp").forward(request, response);  //網(wǎng)址不會(huì)改變  

PS:如果后臺使用的轉(zhuǎn)發(fā)代碼為 response.sendRedirect("welcome.jsp"); //網(wǎng)址變?yōu)閣elcome.jsp

則request設(shè)置的參數(shù)無效猴誊,因?yàn)橐呀?jīng)切換到另一個(gè)請求了潦刃,request參數(shù)的有效期為本次請求。
????(2)前臺代碼

String name=request.getAttribute("name").toString();  

4. 利用Ajax進(jìn)行異步數(shù)據(jù)請求(得到的數(shù)據(jù)可以以json或xml格式返回懈叹,便于處理)

(1)后臺代碼案例(運(yùn)用servlet傳輸數(shù)據(jù))

public class TestServlet extends HttpServlet { 

    /** * 
        Constructor of the object. 
    */ 
    public TestServlet() { 
        super(); 
    } 
    public void doGet(HttpServletRequest    request, HttpServletResponse response) throws ServletException, IOException { 
        doPost(request, response); 
    } 
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 
        response.setContentType("text/html"); 
        PrintWriter out = response.getWriter(); 
        String data="[{\"name\":\"apple\",\"price\":23},{\"name\":\"banana\",\"price\":12},{\"name\":\"orange\",\"price\":8}]"; 
        out.write(data); 
        out.flush(); 
        out.close(); } 
    
    /**
        Initialization of the servlet. <br> 
    * 
    * @throws ServletException if an error occurs 
    */ 
    public void init() throws ServletException { 
        // Put your code here 
    } 
}

(2)前臺js請求處理數(shù)據(jù)代碼

function createXMLHttpRequest(){ 
    var xmlrequest; 
    if(window.XMLHttpRequest){ 
    xmlrequest=new XMLHttpRequest(); 
    }else if(window.ActiveXObject){ 
        try{ 
            xmlrequest=new ActiveXObject("Msxm12.XMLHTTP"); 
        }catch(e){ 
            try{ 
                xmlrequest=new ActiveXObject("Microsoft.XMLHTTP"); 
            }catch(e){ 
                xmlrequest=""; 
            } 
        } 
    } 
    return xmlrequest; 
} 
//獲取數(shù)據(jù)的函數(shù) 
function change(){ 
    var xmlrequest=createXMLHttpRequest(); 
    xmlrequest.open("POST","TestServlet",true); xmlrequest.onreadystatechange=function(){ 
        if(xmlrequest.readyState==4&&xmlrequest.status==200){ 
            var data=JSON.parse(xmlrequest.responseText); 
            var content="<table border=1>"; 
            for(var i=0;i<data.length;i++){ 
                content+="<tr>"; 
                for(o in data[i]){ 
                    content+="<td>"+data[i][o]+"</td>"; 
                } 
                content+="</tr>"; 
            } 
            content+="</table>"; 
            document.getElementById("test").innerHTML=content; 
        } 
    }; 
    xmlrequest.send(); 
}

總結(jié):

在用戶訪問網(wǎng)站整個(gè)生命周期中都會(huì)用到的數(shù)據(jù)用session來存儲(chǔ)乖杠,例如用戶名,登錄狀態(tài)澄成,購物車信息顯示在網(wǎng)頁上的信息數(shù)據(jù)大多通過 request或Ajax方式獲取.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胧洒,一起剝皮案震驚了整個(gè)濱河市畏吓,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卫漫,老刑警劉巖菲饼,帶你破解...
    沈念sama閱讀 217,907評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異汛兜,居然都是意外死亡巴粪,警方通過查閱死者的電腦和手機(jī)通今,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評論 3 395
  • 文/潘曉璐 我一進(jìn)店門粥谬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人辫塌,你說我怎么就攤上這事漏策。” “怎么了臼氨?”我有些...
    開封第一講書人閱讀 164,298評論 0 354
  • 文/不壞的土叔 我叫張陵掺喻,是天一觀的道長。 經(jīng)常有香客問我储矩,道長感耙,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,586評論 1 293
  • 正文 為了忘掉前任持隧,我火速辦了婚禮即硼,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘屡拨。我一直安慰自己只酥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評論 6 392
  • 文/花漫 我一把揭開白布呀狼。 她就那樣靜靜地躺著裂允,像睡著了一般。 火紅的嫁衣襯著肌膚如雪哥艇。 梳的紋絲不亂的頭發(fā)上绝编,一...
    開封第一講書人閱讀 51,488評論 1 302
  • 那天,我揣著相機(jī)與錄音貌踏,去河邊找鬼十饥。 笑死,一個(gè)胖子當(dāng)著我的面吹牛哩俭,可吹牛的內(nèi)容都是我干的绷跑。 我是一名探鬼主播,決...
    沈念sama閱讀 40,275評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼凡资,長吁一口氣:“原來是場噩夢啊……” “哼砸捏!你這毒婦竟也來了谬运?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,176評論 0 276
  • 序言:老撾萬榮一對情侶失蹤垦藏,失蹤者是張志新(化名)和其女友劉穎梆暖,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體掂骏,經(jīng)...
    沈念sama閱讀 45,619評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡轰驳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了弟灼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片级解。...
    茶點(diǎn)故事閱讀 39,932評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖田绑,靈堂內(nèi)的尸體忽然破棺而出勤哗,到底是詐尸還是另有隱情,我是刑警寧澤掩驱,帶...
    沈念sama閱讀 35,655評論 5 346
  • 正文 年R本政府宣布芒划,位于F島的核電站,受9級特大地震影響欧穴,放射性物質(zhì)發(fā)生泄漏民逼。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評論 3 329
  • 文/蒙蒙 一涮帘、第九天 我趴在偏房一處隱蔽的房頂上張望拼苍。 院中可真熱鬧,春花似錦焚辅、人聲如沸映屋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,871評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽棚点。三九已至,卻和暖如春湾蔓,著一層夾襖步出監(jiān)牢的瞬間瘫析,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,994評論 1 269
  • 我被黑心中介騙來泰國打工默责, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贬循,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,095評論 3 370
  • 正文 我出身青樓桃序,卻偏偏與公主長得像杖虾,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子媒熊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法奇适,類相關(guān)的語法坟比,內(nèi)部類的語法,繼承相關(guān)的語法嚷往,異常的語法葛账,線程的語...
    子非魚_t_閱讀 31,631評論 18 399
  • 本文包括:1、Filter簡介2皮仁、Filter是如何實(shí)現(xiàn)攔截的籍琳?3、Filter開發(fā)入門4贷祈、Filter的生命周期...
    廖少少閱讀 7,272評論 3 56
  • JSP總結(jié)(經(jīng)典) day1 JSP 定義: 1)Java Server Page, Java EE 組件趋急,本...
    java日記閱讀 3,444評論 0 13
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)付燥,斷路器宣谈,智...
    卡卡羅2017閱讀 134,656評論 18 139
  • 別名:薛愈犹、牡贊键科、木蓮、木蓮藤漩怎、過水龍勋颖、辟萼、石壁蓮勋锤、木瓜藤饭玲、膨泡樹、壁石虎叁执、木壁蓮茄厘、爬墻虎、風(fēng)不動(dòng)谈宛、彭蜂藤次哈、王不留...
    本草園丁閱讀 3,245評論 0 0