這篇文章主要為大家展示了“web開發(fā)中如何解決表單重復提交的三種情況”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“web開發(fā)中如何解決表單重復提交的三種情況”這篇文章吧。
創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供永和網(wǎng)站建設(shè)、永和做網(wǎng)站、永和網(wǎng)站設(shè)計、永和網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、永和企業(yè)網(wǎng)站模板建站服務(wù),十載永和做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。
第一種情況:提交完表單以后,不做其他操作,直接刷新頁面,表單會提交多次。
- 在servlet中寫一句輸出,用來判斷是否提交多次
System.out.println("已經(jīng)插入"); request.getRequestDispatcher("/login_success.jsp").forward(request, response);
- 這樣的話,刷新多少次,就會在控制器顯示多少個“已經(jīng)插入”。
- 根本原因:Servlet處理完請求以后,直接轉(zhuǎn)發(fā)到目標頁面,這樣整個業(yè)務(wù)只發(fā)送了一次請求,那么當你在瀏覽器中點擊刷新會一直都會刷新之前的請求。
- 解決方法:不用轉(zhuǎn)發(fā)到另一頁面,采用重定向的方式跳轉(zhuǎn)到目標頁面
response.sendRedirect("/day0815-session/login_success.jsp");
第二種情況:在提交表單時,如果網(wǎng)速較差,可能會導致點擊提交按鈕多次,這種情況也會導致表單重復提交。
- 解決方法:點擊提交按鈕之后,使按鈕不可用。通過js完成
- 注意“提交”按鈕,此時已經(jīng)不可按!
第三種情況:表單提交成功以后,直接點擊瀏覽器上回退按鈕,不刷新頁面,然后點擊提交按鈕再次提交表單。
- 根本原因:因為服務(wù)器在處理請求時,不會檢查是否為重復提交的請求。
- 解決方案:
使用一個token的機制
- token就是令牌的意思
- 服務(wù)器在處理請求之前先來檢查瀏覽器的token
- token由服務(wù)器來創(chuàng)建,并交給瀏覽器,瀏覽器在向服務(wù)器發(fā)送請求時需要帶著這個token
- 服務(wù)器處理請求前檢查token是否正確,如果正確,則正常處理,否則返回一個錯誤頁面
- 服務(wù)器所創(chuàng)建的token只能使用一次
- token一般使用一個唯一的標識
- 在jsp頁面,獲取uuid作為token
- UUID:32位字符串,通常作為對象或者表的唯一標識,根據(jù)機器碼和時間戳(從1970年1月1日開始到現(xiàn)在)生成。
<% String uuid = UUID.randomUUID().toString(); session.setAttribute("uuid", uuid); %>
${errormsg }
- 在servlet頁面
String reqUUID = request.getParameter("uuid"); HttpSession session = request.getSession(); String sessUUID = (String) session.getAttribute("uuid"); session.removeAttribute("uuid"); if(reqUUID.equals(sessUUID)){ response.sendRedirect(request.getContextPath()+"/login_success.jsp"); System.out.println("已經(jīng)插入"); }else{ request.setAttribute("errormsg", "重復登陸"); request.getRequestDispatcher("/3.jsp").forward(request, response); }
- 表單重復提交的危害:
- 向數(shù)據(jù)庫中插入大量的重復且沒有意義的數(shù)據(jù),占用服務(wù)器的資源
- 處理請求服務(wù)器并沒有檢查請求是否為重復的請求,導致惡意的攻擊
以上是“web開發(fā)中如何解決表單重復提交的三種情況”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!