java - SpringMvc没有根据&符号截取参数
PHP中文网
PHP中文网 2017-04-18 10:49:01
0
4
606
  var url =  $('input[name="itemCode"]').val() +'/join.html?userid='+ $('input[name="userid"]').val()+'&telphone='+phone+'&axdversion='+ version +'&itemId='+ $('input[name="itemId"]').val();
  request.reqLocation(url);

Js中拼出了一个url,之后便跳转Url。其中

    reqLocation : function(url){            
        window.location = url;
    },

后端代码:

public ModelAndView registerHtml(String itemCode, Long itemId, Long userid, HttpServletRequest request,    HttpServletResponse response) {
       ......//业务代码
}

但是在有些情况下会由于参数问题报错:

【/item/zxyh/join.html】【{userid=14&itemCode=xyz&itemId=8:}】 java.lang.NullPointerException at channel.web.item.OpenItemController.down(OpenItemController.java:468) at sun.reflect.GeneratedMethodAccessor165.invoke(Unknown Source) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorIm

正确的应该像这样:

【/item/zxyh/join.html】【{itemId:123},{itemCode:xyz},{userid:1}】

springMVC 并没有根据&符号,将各种参数赋值。所以导致我的itemCode之类的参数为空。
js是手机端的,并且也只有少量请求会出现这种情况,想知道为什么,或者有没有人遇到同样的问题?

PHP中文网
PHP中文网

认证0级讲师

全部回覆(4)
Ty80

終於找到問題了! !
問題的原因應該是惡意攻擊,利用工具注入了參數。具體怎麼做的就不太清楚了。

PHPzhong

@RequestParam

百度之

左手右手慢动作

這個好像跟SpringMVC沒關係吧,如果JS中沒有取到itemId,伺服器端拿到的自然是NULL。

洪涛

出錯的情況下,前端調試下拼出的url中,各參數值是否正常,後端查看請求request中是否包含以上參數,以及它們的值

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板