您好,登錄后才能下訂單哦!
先貼出來簡單得不能再簡單的demo頁面效果:
如下是spring mvc的Controller:
@RequestMapping("mytest")
@Controller
public class ZhangTestController {
private Logger log = LogManager.getLogger();
@RequestMapping(value = "toCancel")
public String toCancel( HttpServletRequest request, HttpServletResponse response, String orderNo){
log.info("orderNo={}",orderNo);
request.setAttribute("orderNo", null);
return "mytest/toCancel";
}
}
如下toCancel.jsp頁面,
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@ page contentType="text/html;charset=UTF-8" %>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<script type="text/javascript" src="${pageContext.request.contextPath}/static/yimei/js/jquery-1.10.2.js"></script>
<script type="text/javascript">
$(document).ready(function () {
$("#chargeQuery").click(function () {
$("#inputForm").submit();
});
});
</script>
</head>
<body>
<form id="inputForm" action="" method="post" class="form-horizontal">
<input type="text" name="orderNo" id="orderNo" value="${orderNo}"/>
</form>
<span class="buyer pay-credit" id="chargeQuery">取消訂單</span>
</body>
</html>
如上,當通過瀏覽器訪問http://localhost:8083/mytest/toCancel?orderNo=123,通過log可知打印出來的orderNo=123,這沒什么可質疑的。
but,然后,再點擊頁面上的“取消訂單”,打印出來的日志你猜是什么?好奇的你,急于想知道答案的話就Ctrl+A吧~~orderNo=123,null
是不是完全出乎你的意料?!
如何解釋這種情況?
我的理解:servlet在解析請求參數的值時,會通過逗號拼接所有地方的請求。本例orderNo參數的取值,包括get方式的orderNo參數,還包括form表單里的name="orderNo"域的值,所以,點擊按鈕事件時,orderNo參數的值是“123,null”。
今天在對生產排障時,奇怪的發現,查單的sql語句里,where條件中orderNo的參數值不是一個特定的字符串,而是“123,null”或“123,123”,最后發現原來是jsp頁面和webcontroller交互處理不當導致的。本文記錄下來,以備園子里其他同學做參考。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。