restful 接口使用踩坑

不谈概念,只讨论一下怎么使用。工作上遇到的坑,记录一下。

环境:

既然是restful api,那么,前端使用jQuery ajax发送http请求,传递json类型的值。后端使用springboot来接收。


方式1
前端代码
        var data = {
            "bizData": "abc",
            "bizSignature":"xxx",
            "transSignature":"xxx",
            "trans" : {
                "type":"1",
                "mac":"xxxx",
                "serverNo":"xxxx",
                "supvLoctNo":"xxxx"
            }
        };

        $.ajax({
            url: "http://localhost:9200/bbb1",
            type: "GET",
            data: data,
            success: function () {
                //
            }
        });
后端代码
@RestController
public class OutSystemApi {
    @GetMapping("/bbb1")
    public void OutInfoSystemIOgdsdclBsc(OutSystemVO outSystemVO){
        int a = 1;
    }
}

//POJO类
@Data
public class OutSystemVO {
    //业务数据
    private String bizData;

    //业务签名
    private String bizSignature;

    //传输签名
    private String transSignature;
}

很奇怪data中第一层的字段在java后端是可以正确映射的,而trans里面的内容,前端把他解析成了trans[mac]数组的形式,后端解析就直接报错了,不知道为什么。

Resolved exception caused by Handler execution: org.springframework.beans.InvalidPropertyException: Invalid property 'trans[mac]' of bean class [com.demo.model.vo.OutSystemVO]: Property referenced in indexed property path 'trans[mac]' is neither an array nor a List nor a Map; returned value was [cn.gov.customs.hsservice.model.vo.OutSystemTranVO@46146ca3]

然后在来看一段正常的代码

方式2
        var data = {
            bizData: "abc",
            bizSignature:"xxx",
            transSignature:"xxx",
            trans: {
                type:"1",
                mac:"xxxx",
                serverNo:"xxxx",
                supvLoctNo:"xxxx"
            }
        };

        $.ajax({
            url: "http://localhost:9200/bbb1",
            type: "POST",
            data: JSON.stringify(data),
            contentType: "application/json",
            success: function () {
                //
            }
        });
  @PostMapping("/bbb1")
    public void OutInfoSystemIOgdsdclBsc(@RequestBody OutSystemVO outSystemVO){
        int a = 1;
    }

这里 contentType: "application/json",http头部是需要指明为application/json类型。如果指定了类型,那么后端就要使用@RequestBody接收。但是其实浏览器还是很智能的,如果没有设置header的conten-type, 在body中传递了对象,浏览器会自动将content-type改成application/json。
而再来看看@RequestBody标签的意思:

@requestBody注解常用来处理content-type不是默认的application/x-www-form-urlcoded编码的内容,比如说:application/json或者是application/xml等。一般情况下来说常用其来处理application/json类型。


方式3

一般正常的提交操作都是用方式2的,但在一些特殊的情况下可能就不满足需求了。
我们假设有这样一个需求,先需要取出提交上来数据的值,然后把值都拼在一起,拼成一个字符串,之后再进行业务操作。这里对前端提交的数据字段顺序就有要求了,如果每次都使用一样的顺序,可能就会出现问题。
java端我们使用的是一个pojo对象来接收前端的json数据。spring会自己使用Jackson包来把json字符串序列化成一个对象,那么就无法获得前端提交的字段顺序了。
也许我们可以这么干:

前端代码:
        var bizData = {"idno":"360415844564456","igdsdclBscNo":"ccc804505f2a4f1d88267bf009acf751"}

        var data = {
            "transSignature":"xxx",
            "bizData": bizData,
            "bizSignature":"xxx",
            "trans" : {
                "type":"1",
                "mac":"xxxx",
                "serverNo":"xxxx",
                "supvLoctNo":"xxxx"
            }
        };

        $.ajax({
            url:"http://localhost:9200/bbb",
            type: "POST",
            data: JSON.stringify(data),
            contentType: "application/json"
        });
后端代码:
 @PostMapping("/bbb")
    public void OutInfoSystemIOgdsdclBsc2(HttpServletRequest request){
        JSONObject jsonParam = null;
        try {
            // 获取输入流
            BufferedReader streamReader = new BufferedReader(new InputStreamReader(request.getInputStream(), "UTF-8"));

            // 写入数据到Stringbuilder
            StringBuilder sb = new StringBuilder();
            String line = null;
            while ((line = streamReader.readLine()) != null) {
                sb.append(line);
            }
            jsonParam = JSONObject.parseObject(sb.toString(), Feature.OrderedField);
            // 直接将json信息打印出来
            System.out.println(jsonParam.toJSONString());
        } catch (Exception e) {
            e.printStackTrace();
        }

        int a = 1;
    }

通过HttpServletRequest 对象来获取到输入流,然后将输入流的数据写入到字符串里面,最后转化为JSON对象。注意这里的parseObject存储对象内容使用的map,这将导致最后取得的数据是无顺序的,我们需要再添加一个参数Feature.OrderedField。 获得所有的json内容之后,再映射到具体的pojo对象上去。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,837评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,551评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,417评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,448评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,524评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,554评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,569评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,316评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,766评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,077评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,240评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,912评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,560评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,176评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,425评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,114评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,114评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,988评论 25 707
  • 晚上男票送我回来的路上 男票一直在教育我,哎……我也很无奈 于是就想转移换题,就特别煽情的告诉他,如果我们高中就认...
    言不由衷词不达意阅读 187评论 0 0
  • 在这个看脸的时代,颜值的重要性不用我说你们也知道。「靠脸吃饭」是普遍现象,但你有没有发现,有时候吃饭也要靠“脸”。...
    果核健身阅读 466评论 0 1
  • 梵高切下一只耳朵,面对镜子画像 血液在南方流淌,一切都在沸腾! 向日葵,太阳,还有急速旋转的星空 那是燃烧的孤独与...
    原朔阅读 386评论 0 3