美文网首页
序列化前端请求后端接收不到-03-27

序列化前端请求后端接收不到-03-27

作者: 封_绝 | 来源:发表于2019-03-27 19:49 被阅读0次

    前端使用js ajax post发送请求

    var course = $(".js_form").serialize();
            $.post($(".js_form").attr("action") + "?createTime=" + $(".js_createTime").val(), course, function (data) {
                if (data == true) {
                    layer.alert('添加成功!', {icon: 6, time: 2000}, function () {
                        window.location.reload();
                    });
                } else {
                    layer.alert('添加失败!', {icon: 5});
                }
            });
    

    首先js使用serialize方法将输入框对象序列化了,序列化之后的值:a=1&b=2&c=3&d=4&e=5。
    如果有中文则会出现乱码现象,
    例如:coursenumber=1553617956169&specialtyid=%E8%AE%A1%E7%AE%97%E6%9C%BA%E5%AD%A6%E7%94%9F%E4%BC%9A&specialtyid=%E8%AE%A1%E7%AE%97%E6%9C%BA%E5%AD%A6%E9%99%A2%E5%AD%A6%E7%94%9F%E4%BC%9A%E7%AE%A1%E7%90%86%E5%91%98&name=1&credit=1&schooltime=1&address=1&numberlimit=1&detail=1

    可以看出来很像是用get方法传值

    后端接收方法

    //可以是
    @RequestMapping("addCourse")
        @ResponseBody
        public boolean addCourse(Course course, String createTime) {
            Date date = DateStrConvert.strToDate(createTime, "yyyy-MM-dd");
            course.setCreatetime(date);
            course.setNumberspace(course.getNumberlimit());
            System.out.println(course);
            return courseService.addCourse(course);
        }
    

    直观理解,前端传来两个参数,后端接收两个参数没有什么问题。
    但是仔细想想,前端create Time用get方法传值,但是course用的是post方法传值。这样参数的接收也没有什么问题吗?请求映射有一种写法是@RequestMapping(value = "sendMail", method = RequestMethod.POST),如果是这样的话是不是只能接收post请求的参数了呢?

    另外post请求一般会用json对象进行传递数据,{"需要映射的参数名称":参数值, ... }。js是弱类型的脚本语言,一般用var 声明,如果对象不是基本类型,那如何创建呢?如果类型不同,如何保证不出现问题呢?类型的转换处理过程又是如何的呢?

    而在这个工程中并有没有使用json,而是直接传值,所以这用的是post方法吗?


    不是用post方法请求,有待考察

    $.get(URL,callback);

    $.post(URL,data,callback);

    测试

    后端可以通过变量名将各个值匹配给course的各个属性,中间应该是有一个类型转换的过程,在我们的测试中,credit声明为Integer类型,传递一个0.1是无法进行转换的。
    至于前端的course这个变量名是否一定要和后端变量名一致,这个是否定的,因为我们即使直接使用url访问,也是可以匹配到映射的类,并且将值赋给Course的各个属性。使用如下url
    http://localhost:8080/addCourse.do?createTime=1905-10-10&coursenumber=1553671091061&specialtyid=1&teacherid=2&name=%E8%AE%A1%E7%AE%97%E6%9C%BA%E5%AD%A6%E7%94%9F%E4%BC%9A&credit=1&schooltime=2019-03-27+15%3A03&address=1&numberlimit=1&detail=

    如果在上面post中使用json,即

     $.post($(".js_form").attr("action") + "?createTime=" + $(".js_createTime").val(), course, function (data)
    //改为
     $.post($(".js_form").attr("action") + "?createTime=" + $(".js_createTime").val(), {'course':course}, function (data)
    

    映射的方法虽然能够匹配,但是Course的各个值都是null

    所以猜测这应该是一个get请求,后端接收值的时候能够解析方法的类属性,并且自动匹配和类型的转化,不过编码是怎么解决的呢?这个是SpringMVC中设置了一个解码格式还是人为配置?

        @RequestMapping("addCourse")
        @ResponseBody
        public boolean addCourse(String coursenumber, String specialtyid, String name,
                                 String credit, String schooltime,String address, String numberlimit, String detail) {
    
            System.out.println("test");
            return true;
        }
    

    接收不到
    因为没有redeploy,仅仅是update classes 和 resource好像经常有问题,最后可以接收到

    相关文章

      网友评论

          本文标题:序列化前端请求后端接收不到-03-27

          本文链接:https://www.haomeiwen.com/subject/qteavqtx.html