JavaWeb程序設(shè)計 課件 ch05 表單開發(fā)、ch06 JSP訪問數(shù)據(jù)庫_第1頁
JavaWeb程序設(shè)計 課件 ch05 表單開發(fā)、ch06 JSP訪問數(shù)據(jù)庫_第2頁
JavaWeb程序設(shè)計 課件 ch05 表單開發(fā)、ch06 JSP訪問數(shù)據(jù)庫_第3頁
JavaWeb程序設(shè)計 課件 ch05 表單開發(fā)、ch06 JSP訪問數(shù)據(jù)庫_第4頁
JavaWeb程序設(shè)計 課件 ch05 表單開發(fā)、ch06 JSP訪問數(shù)據(jù)庫_第5頁
已閱讀5頁,還剩53頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

第5章表單開發(fā)本課教學(xué)內(nèi)容認識表單單一表單元素數(shù)據(jù)的獲取捆綁表單元素數(shù)據(jù)的獲取隱藏表單其他問題表單開發(fā)表單是用戶和服務(wù)器之間進行信息交互的重要手段,有了表單,JSP程序才可以更加豐富多彩。表單是一種可以由用戶輸入,并提交給服務(wù)器端的一個圖形界面。表單開發(fā)表單有如下性質(zhì):表單中可以輸入一些內(nèi)容,這些輸入功能由控件提供,叫做表單元素表單中一般都有一個按鈕負責(zé)提交點擊提交按鈕,表單元素中的內(nèi)容會提交給服務(wù)器端表單元素放在<form></form>之間表單開發(fā)表單是提交給服務(wù)器的,如何確定到底提交給哪一個界面?用<form>中的action屬性確定。如:<formaction="page.jsp"> 請您輸入賬號:<inputname="account"type="text"><BR> 請您輸入密碼:<inputname="password"type="password"><BR> <inputtype="submit"value="登錄"> </form>表示該表單中輸入的內(nèi)容,提交給page.jsp去運行。表單開發(fā)page.jsp如何獲取提交過來的值?用request對象。如:<%//獲得表單中name=account的表單元素中輸入的值,賦值給strStringstr=request.getParameter("account");%>注意:如果表單中沒有name=account的表單元素,str為null;如果在表單元素account中沒有輸入任何內(nèi)容就提交,str為""。表單開發(fā)<inputtype="submit"value="登錄">表示提交按鈕,可以寫普通按鈕嗎?不行,如果將該按鈕改為:<inputtype="button"value="登錄">,顯示效果一樣,但是點擊,沒有提交功能。不過可以用JavaScript進行提交。單一表單元素數(shù)據(jù)的獲取單一表單元素,是指表單元素的值送給服務(wù)器端時,僅僅是一個變量。這種情況下的表單元素主要有:文本框、密碼框、多行文本框、單選按鈕、下拉菜單等。單一表單元素數(shù)據(jù)的獲取文本框、密碼框、多行文本框、單選按鈕和下拉菜單,其中的內(nèi)容的獲取方法均相同,利用request.getParameter("表單元素名")方法獲得一個字符串。*具體代碼示例見課本捆綁表單元素數(shù)據(jù)的獲取捆綁表單元素,是指多個同名表單元素的值送給服務(wù)器端時,是一個捆綁的數(shù)組。這種情況下的表單元素主要有:復(fù)選框、多選列表框、其他同名表單元素等。捆綁表單元素數(shù)據(jù)的獲取具體獲得方法和一般表單元素類似,但在獲取數(shù)據(jù)時,利用request.getParameterValues("表單元素名")方法來獲得字符串?dāng)?shù)組。*具體代碼示例見課本獲取其他同名表單元素中的數(shù)據(jù)

多個同名文本框是如何存儲在獲取到的數(shù)組里的?以文本框在源代碼中出現(xiàn)的順序,從數(shù)組的第0位開始向后放置。隱藏表單例子:頁面1中定義了一個數(shù)值變量,并顯示其平方;要求在頁面2中顯示其立方。很明顯,頁面2必須知道頁面1中定義的那個變量。可以用URL傳值。但是通過URL方法,傳遞的數(shù)據(jù)可能被看到。為了避免這個問題,我們可以用表單將頁面1中的變量傳給頁面2,這個表單就可以設(shè)定為頁面1中的隱藏表單。隱藏表單網(wǎng)頁制作中,input有一type="hidden"的選項,它是隱藏在網(wǎng)頁中的一個表單元素,并不在網(wǎng)頁中顯示出來。這就是實現(xiàn)隱藏表單的方法。實現(xiàn)方法:隱藏表單此時瀏覽器地址欄上的地址數(shù)據(jù)還是能夠被看到。解決該問題的方法是將form的action屬性設(shè)置為post(默認為get)解決數(shù)據(jù)傳輸安全問題方法:隱藏表單隱藏表單的弊端和URL方法類似,該方法傳輸?shù)臄?shù)據(jù)只能是字符串,對數(shù)據(jù)類型具有一定限制傳輸數(shù)據(jù)的值雖然在瀏覽器地址欄內(nèi)不被看到,但是在客戶端源代碼里面也會被看到*具體代碼示例見課本用JavaScript進行提交有時候,可能要對表單中的輸入進行一些驗證。如在登錄表單中,需要輸入的賬號密碼不能為空。因此,當(dāng)點擊提交按鈕時,不能馬上提交,應(yīng)該調(diào)用JavaScript進行驗證,然后進行提交。因此,提交按鈕的類型不能被設(shè)置為submit,而應(yīng)該設(shè)置為button。*具體代碼示例見課本中文亂碼問題如果使用的是Tomcat服務(wù)器,在提交過程中,如果提交的內(nèi)容中含有中文,經(jīng)常會出現(xiàn)中文亂碼問題。

中文亂碼問題中文無法顯示 沒有把文件頭上的字符集設(shè)置為中文字符集。一定要保證文件頭上寫明:<%@pagelanguage="java"pageEncoding="gb2312"%>或 <%@pagelanguage="java"contentType="text/html;charset=gb2312"%>

中文亂碼問題提交過程中顯示亂碼,有3種方法解決這個問題將其轉(zhuǎn)成gb2312格式直接修改request的編碼利用過濾器

中文亂碼問題將其轉(zhuǎn)成gb2312格式方法如下:變量(字符串)=newString(變量(字符串).getBytes("ISO-8859-1"),"gb2312")中文亂碼問題直接修改request的編碼可以將request的編碼修改為支持中文的編碼,這樣,整個頁面中的請求,都可以自動轉(zhuǎn)為中文request.setCharacterEncoding("gb2312")中文亂碼問題利用過濾器 利用過濾器,可以對整個Web應(yīng)用進行統(tǒng)一的編碼過濾,比較方便。該內(nèi)容在后面的章節(jié)中提到*具體代碼實例見課本本章結(jié)束本章總結(jié)表單開發(fā)隱藏表單其他問題上機習(xí)題第6章JSP訪問數(shù)據(jù)庫本課教學(xué)內(nèi)容JDBC簡介建立ODBC數(shù)據(jù)源JDBC操作使用PreparedStatement事務(wù)使用廠商驅(qū)動進行數(shù)據(jù)庫連接JDBC簡介商業(yè)應(yīng)用的后臺數(shù)據(jù)一般存放在數(shù)據(jù)庫中,很明顯,可以通過Java代碼來訪問數(shù)據(jù)庫。在Java技術(shù)系列中,訪問數(shù)據(jù)庫的技術(shù)叫做JDBC,它提供了一系列的API,讓Java語言編寫的代碼連接數(shù)據(jù)庫,對數(shù)據(jù)庫的數(shù)據(jù)進行添加、刪除、修改和查詢JDBC簡介JDBC中以下類或接口java.sql.Connection:負責(zé)連接數(shù)據(jù)庫

java.sql.Statement:負責(zé)執(zhí)行數(shù)據(jù)庫SQL語句java.sql.ResultSet:負責(zé)存放查詢結(jié)果JDBC簡介針對不同類型的數(shù)據(jù)庫,JDBC機制中提供了"驅(qū)動程序"的的概念。對于不同的數(shù)據(jù)庫,程序只需要使用不同的驅(qū)動廠商驅(qū)動連接數(shù)據(jù)庫JDBC簡介安裝數(shù)據(jù)庫廠商驅(qū)動,需要去各自的數(shù)據(jù)庫廠商網(wǎng)站下載驅(qū)動包,用戶也許覺得很麻煩。此時,微軟公司提供了一個解決的方案。在微軟公司的Windows中,預(yù)先設(shè)計了一個ODBC(OpenDatabaseConnectivity,開放數(shù)據(jù)庫互連)功能,由于ODBC是微軟公司的產(chǎn)品,因此它幾乎可以連接到所有在Windows平臺下運行的數(shù)據(jù)庫,由它連接到特定的數(shù)據(jù)庫,不需要具體的驅(qū)動。而JDBC就只需要連接到ODBC就可以了

JDBC簡介ODBC驅(qū)動連接數(shù)據(jù)庫建立ODBC數(shù)據(jù)源在使用ODBC之前,需要配置ODBC的數(shù)據(jù)源,讓ODBC知道連接的具體數(shù)據(jù)庫ODBC支持連接到各種數(shù)據(jù)庫。如Oracle、MySQL、MSSQLServer等,具體的設(shè)置詳見課本圖解過程建立ODBC數(shù)據(jù)源在配置時,要注意:access的數(shù)據(jù)源驅(qū)動器都是32位的,64位機上可能會找不到access數(shù)據(jù)源驅(qū)動器。對于64位機,可以打開32位版本的ODBC管理工具,其界面和設(shè)置過程與32位的相同。由于JDK1.8及以上的版本都已經(jīng)不再包含access橋接驅(qū)動,在使用JDBC-ODBC橋接方式時,需要下載access驅(qū)動的jar包,具體操作方法大家可以參見其他詳細文檔。建立ODBC數(shù)據(jù)源操作如下:首先在控制面板中選擇"管理工具",雙擊"數(shù)據(jù)源(ODBC)圖標(biāo)"建立ODBC數(shù)據(jù)源操作如下:在"ODBC數(shù)據(jù)源管理器"的"系統(tǒng)DSN"選項卡中單擊"添加"按鈕建立ODBC數(shù)據(jù)源操作如下: 從彈出的"創(chuàng)建新數(shù)據(jù)源"窗口的數(shù)據(jù)源名稱列表中選擇"MicrosoftAccesDriver(*.mdb)"并單擊"完成"按鈕建立ODBC數(shù)據(jù)源操作如下:在彈出的"ODBCMicrosoftAccess安裝"窗口的"數(shù)據(jù)源名"文本框輸入自定義的數(shù)據(jù)源名稱,然后點擊"選擇"按鈕,選擇Access數(shù)據(jù)庫所在的目錄,得到的結(jié)果如圖JDBC操作JDBC的操作分為4個步驟:通過JDBC連接到ODBC,并獲取連接對象Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");Connectionconn=DriverManager.getConnection("jdbc:odbc:DSSchool");JDBC操作

使用Statement接口運行SQL語句Statementstat=conn.createStatement();stat.executeQuery(SQL語句);//查詢或者

stat.executeUpdate(SQL語句);//添加、刪除或修改

JDBC操作處理SQL語句運行結(jié)果關(guān)閉數(shù)據(jù)庫連接:stat.close();conn.close();添加數(shù)據(jù)具體添加案例見課本在這里,重點介紹下面一句代碼: inti=stat.executeUpdate(sql);

它返回一個整型,意思為這條sql語句執(zhí)行受影響的行數(shù),即成功添加的條數(shù)刪除、修改數(shù)據(jù)具體代碼案例見課本兩種操作均調(diào)用stat.executeUpdate(sql),并返回一個整型量查詢數(shù)據(jù)具體代碼案例見課本查詢格式: ResultSetrs=stat.executeQuery(sql);查詢到的結(jié)果放入ResultSet中,實際上是一個小表格查詢數(shù)據(jù)游標(biāo) 是在ResultSet中一個可以移動的指針,它指向一行數(shù)據(jù)。初始時指向第一行的前一行,實際上不指向任何數(shù)據(jù)。rs.next()可以將游標(biāo)移到下一行,它的返回值是一個布爾類型,即如果下一行有數(shù)據(jù)則返回為true,否則為flase。很明顯,可以使用rs.next()配上while循環(huán)來對結(jié)果進行遍歷查詢數(shù)據(jù)游標(biāo) 當(dāng)游標(biāo)指向某一行,可以通過ResultSet的getXXX("列名")方法得到這一行的某個數(shù)據(jù), XXX是該列的數(shù)據(jù)類型,可以是String,也可以是int等,但是所有類型的數(shù)據(jù)都可以用getString()方法獲得。除了通過列名獲得數(shù)據(jù)外,還可以通過列的編號來獲得查詢數(shù)據(jù)關(guān)于游標(biāo)的注意 游標(biāo)的初始值并不是指向第1行數(shù)據(jù),而是指向第1行的前面那條數(shù)據(jù)。所以必須要運行一次next()函數(shù)之后,才能從開始取數(shù)據(jù),如果強行取則會找不到該列而報錯查詢數(shù)據(jù)關(guān)于游標(biāo)的注意從某一行中通過getXXX()方法取數(shù)據(jù)每一列只能取一次,超過一次,程序?qū)箦e,如果需要重復(fù)使用某列數(shù)據(jù),可以先定義一個變量,將取出的數(shù)據(jù)賦予它,再重復(fù)使用使用PreparedStatement引出 以添加數(shù)據(jù)為例,在很多情況下,具體需要添加的值,是由客戶自己輸入的,因此,應(yīng)該是一個個變量。該情況下,SQL語句的寫法就比較麻煩,而且依賴了變量,比較容易出錯PreparedStatement解決了這個問題

使用PreparedStatementPreparedStatement是Statement的子接口,功能與Statement類似它在sql語句中使用了?代替了需要插入的參數(shù) 用PreperedStatement的setString(n,參數(shù))方法可以將第n個?用傳進的參數(shù)代替。這樣做增加了程序的可維護性,也增加了程序的安全性事務(wù)在銀行轉(zhuǎn)賬時,要對數(shù)據(jù)庫進行兩個操作,即將一個賬戶的錢減少,將另一個賬戶的錢增多。但是由于操作的先后順序,如果在兩個操作之間發(fā)生故障,則會導(dǎo)致數(shù)據(jù)不一致。因此,需要設(shè)計一個事務(wù),在兩條語句都被執(zhí)行成功后,數(shù)據(jù)修改才被真正提交(Commit)放入數(shù)據(jù)庫,否則數(shù)據(jù)操作回滾(Rollback)事務(wù)在默認情況下,executeUpdate函數(shù)會在數(shù)據(jù)庫中提交改變的結(jié)果,此時,可以用Connection來定義該函數(shù)是否自動提交改變結(jié)果,并進行事務(wù)的提交或者回滾使用廠商驅(qū)動進行數(shù)據(jù)庫連接缺點:這類驅(qū)動程序的彈性較差,由于是數(shù)據(jù)庫廠商自己提供的專屬驅(qū)動程序,往往只適用于自己的數(shù)據(jù)庫系統(tǒng),甚至只適合某個版本的數(shù)據(jù)庫系統(tǒng)。如果后臺數(shù)據(jù)庫換了一個或者版本升級了,則就有可能需要更換數(shù)據(jù)庫驅(qū)動程序優(yōu)點:跨平臺使用廠商驅(qū)動進行數(shù)據(jù)庫連接使用廠商驅(qū)動,有2個步驟: 到相應(yīng)的數(shù)據(jù)庫廠商網(wǎng)站上下載廠商驅(qū)動,或者從數(shù)據(jù)庫安裝目錄下找到相應(yīng)的廠商驅(qū)動包,拷貝到項目的WEB-INF/lib下。在JDBC代碼中,設(shè)定特定的驅(qū)動程序名稱和url,

不同的驅(qū)動程序和不同的數(shù)據(jù)庫可以采用不同的驅(qū)動名稱和url。使用廠

溫馨提示

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

評論

0/150

提交評論