溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

web開發(fā)中如何解決表單重復(fù)提交的三種情況

發(fā)布時間:2021-07-16 15:03:01 來源:億速云 閱讀:515 作者:小新 欄目:web開發(fā)

這篇文章主要為大家展示了“web開發(fā)中如何解決表單重復(fù)提交的三種情況”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“web開發(fā)中如何解決表單重復(fù)提交的三種情況”這篇文章吧。

第一種情況:提交完表單以后,不做其他操作,直接刷新頁面,表單會提交多次。

- 在servlet中寫一句輸出,用來判斷是否提交多次

System.out.println("已經(jīng)插入");
request.getRequestDispatcher("/login_success.jsp").forward(request, response);

- 這樣的話,刷新多少次,就會在控制器顯示多少個“已經(jīng)插入”。

web開發(fā)中如何解決表單重復(fù)提交的三種情況

- 根本原因:Servlet處理完請求以后,直接轉(zhuǎn)發(fā)到目標頁面,這樣整個業(yè)務(wù)只發(fā)送了一次請求,那么當(dāng)你在瀏覽器中點擊刷新會一直都會刷新之前的請求。

- 解決方法:不用轉(zhuǎn)發(fā)到另一頁面,采用重定向的方式跳轉(zhuǎn)到目標頁面

response.sendRedirect("/day0815-session/login_success.jsp");

web開發(fā)中如何解決表單重復(fù)提交的三種情況

第二種情況:在提交表單時,如果網(wǎng)速較差,可能會導(dǎo)致點擊提交按鈕多次,這種情況也會導(dǎo)致表單重復(fù)提交。

- 解決方法:點擊提交按鈕之后,使按鈕不可用。通過js完成

<script type="text/javascript">
 window.onload = function(){ 
  //獲取按鈕的對象
  var btn = document.getElementById("btn");
  //為按鈕綁定單擊響應(yīng)函數(shù)
  btn.onclick = function(){  
   //點擊以后使按鈕不可用
   this.disabled=true; 
   //當(dāng)將提交按鈕設(shè)置為不可用時,會自動取消它的默認行為
   //手動提交表單
   this.parentNode.submit(); 
  };
 };
</script><br><br><form action="${pageContext.request.contextPath }/SessionServlet" ><br>user:<input type="text" name="username"><br>password<input type="password" name="pwd"><br><input type="submit" value="提交" id="btn"> <br></form>

- 注意“提交”按鈕,此時已經(jīng)不可按!

web開發(fā)中如何解決表單重復(fù)提交的三種情況

第三種情況:表單提交成功以后,直接點擊瀏覽器上回退按鈕,不刷新頁面,然后點擊提交按鈕再次提交表單。

- 根本原因:因為服務(wù)器在處理請求時,不會檢查是否為重復(fù)提交的請求。

- 解決方案:

使用一個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);
%><br>${errormsg }<br><form action="${pageContext.request.contextPath }/SessionServlet" ><br>  <input type="text" name="uuid" value="<%=uuid %>"/><br>  user:<input type="text" name="username"><br>  password<input type="password" name="pwd"><br>  <input type="submit" value="提交" "><br></form>

- 在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", "重復(fù)登陸");
 request.getRequestDispatcher("/3.jsp").forward(request, response);
}

- 表單重復(fù)提交的危害:

- 向數(shù)據(jù)庫中插入大量的重復(fù)且沒有意義的數(shù)據(jù),占用服務(wù)器的資源

- 處理請求服務(wù)器并沒有檢查請求是否為重復(fù)的請求,導(dǎo)致惡意的攻擊

以上是“web開發(fā)中如何解決表單重復(fù)提交的三種情況”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI