鍍金池/ 問答/Java  HTML/ axios傳遞數據給springmvc但是報錯,如何解決?

axios傳遞數據給springmvc但是報錯,如何解決?

 export default{
        data () {
            return {
                current_tab_val:"1",
                user: {
                    name: '',
                    password: ''
                },
                ruleInline: {
                    user: [
                        { required: true, message: '請輸入用戶名', trigger: 'blur' }
                    ],
                    password: [
                        { required: true, message: '請輸入密碼.', trigger: 'blur' },
                        { type: 'string', min: 6, message: '密碼長度至少6位', trigger: 'blur' }
                    ]
                }
            }
        },
        methods: {
            handleSubmit(name) {
                this.$refs[name].validate((valid) => {
                    if (valid) {
                        Axios.post('http://localhost:9090/user/login',this.user)
                        .then(res=>{
                            console.log('login.data=',res.data);
                        })
                        .catch(error=>{

                        })
                        this.$Message.success('Success!');
                    } else {
                        this.$Message.error('Fail!');
                    }
                })
            }
        }
    }
 @RequestMapping(value = "/login",method = RequestMethod.POST)
    public String login(@RequestParam String name, @RequestParam String password){
        System.out.println("==============name============="+name);
        AjaxResult result = new AjaxResult();
        if(name.isEmpty()|| password.isEmpty()){
            result.setSuccess(false);
            result.setMsg("用戶名或者密碼不為空!");
            return JSON.toJSONString(result);
        }
        User user = userService.findBy(name,password);
        if(user!=null){
            Map<String, Object> map = new HashMap<>();
            map.put("user",user);
            result.setData(map);
            return JSON.toJSONString(result);
        }else{
            result.setSuccess(false);
            result.setMsg("沒有找到相應的用戶!");
            return JSON.toJSONString(result);
        }
    }

clipboard.png

clipboard.png

我使用@RequestParam或者@PathVariable都不行,請問有人知道如何解決嗎

回答
編輯回答
礙你眼

JSON.stringify or import qs, qs.stringify

2018年4月29日 02:39
編輯回答
墨小羽
  
//調用Axios請求之前加載
//Axios請求攔截器,隨著業(yè)務的復雜,Axios層的使用將會越來越復雜,寫個精簡版的就行了。
Axios.interceptors.request.use(req => {
    let data = req.data
    console.log('befor convert', data)
    let params = new URLSearchParams();
    for (let name in data) {
           params.append(name, data[name])
    }
    req.data = params.toString()
    console.log('after convert', req)
    return req
}, error => {

    return Promise.reject(error)
})

params 傳遞。

2018年3月15日 10:51