欢迎关注方志朋的博客,回复”666“获面试宝典

肯定有不少人会想:这怎么可能呢?

就算用几乎零配置的 SpringBoot,写一个最简单的接口也得有 3 行代码啊!

@RequestMapping("test/{request}")
public String test(@PathVariable String request) {return request + ": Hello World";
}

那 8 个没啥用的 Hello World 接口就得 24 行代码了!

这还没算拼 SQL 连 JDBC 或者调用 ORM 库 的代码呢!

更不用说还要写 XML 配置 的其它库了!

没错,用传统方式就是这样。

获取一个用户:

base_url/get/user

获取一个用户列表:

base_url/get/user/list

获取一个评论:

base_url/get/comment

获取一个评论列表:

base_url/get/comment/list

...

仅仅是查询,一张表(对应客户端的 model)就要两个接口了,如果再加上增删改,批量改批量删,还有统计,那就得有 8 个接口了!

那么我是怎么解决的呢?

同一种类型的请求都只用一个接口:

增 base_url/post删(包括批量) base_url/delete改(包括批量) base_url/put查(包括列表) base_url/get统计 base_url/head

用最常用的查询请求举例:

获取一个用户:

base_url/get/

获取一个用户列表:

base_url/get/

获取一个评论:

base_url/get

获取一个评论列表:

base_url/get

...

都是用同一个接口!我是怎么做到的呢?

APIJSON,对,就它!

我们用 APIJSON 来操作一张表,例如用户表 User,代码写 3 行就够了:

//注册表并添加权限,用默认配置
@MethodAccess
public class User {
//内容一般仅供表字段说明及 Android App 开发使用,服务端不用的可不写。
}//Verifier 内添加权限
accessMap.put(User.class.getSimpleName(), getAccessMap(User.class.getAnnotation(MethodAccess.class)));

或者可以再定制下 POST 请求的角色权限:

@MethodAccess(POST = {UNKNOWN, ADMIN} //只允许未登录角色和管理员角色新增 User,默认配置是 {LOGIN, ADMIN}
)
public class User {}

然后运行下 Server 工程就可以请求了:

URL:http://apijson.cn:8080/get

表单:

{"User": {"id": 82001}
}

返回:

{"User": {"id": 82001,"sex": 0,"name": "Test","tag": "APIJSON User","head": "http://static.oschina.net/uploads/user/19/39085_50.jpg","contactIdList": [82004,82021,70793],"pictureList": ["http://common.cnblogs.com/images/icon_weibo_24.png"],"date": "2017-02-01 19:21:50.0"},"code": 200,"msg": "success"
}

上面只是查了一个 User,如果我们要查女性用户列表,可以这样:

URL:http://apijson.cn:8080/get

表单:

{"[]": { //数组"User": {"sex": 1, //性别为女"@column": "id,name" //只需要id,name这两个字段}}
}

返回:

{"[]": [{"User": {"id": 82002,"name": "Happy~"}},{"User": {"id": 82003,"name": "Wechat"}},{"User": {"id": 82005,"name": "Jan"}}],"code": 200,"msg": "success"
}

User 被多包裹了一层?给数组命名为 User[] 来去掉吧:

表单:

{"User[]": { //提取User"User": {"sex": 1, //性别为女"@column": "id,name" //只需要id,name这两个字段}}

返回:

{"User[]": [{"id": 82002,"name": "Happy~"},{"id": 82003,"name": "Wechat"},{"id": 82005,"name": "Jan"}],"code": 200,"msg": "success"
}

还要进一步提取名字?User-name[] 满足你:

表单:

{"User-name[]": { //提取User.name"User": {"sex": 1, //性别为女"@column": "name" //只需要name这个字段}}
}

返回:

{"User-name[]": ["Happy~","Wechat","Jan","Meria","Tommy"],"code": 200,"msg": "success"
}

但如果是含多张表关联的数组,就不要去掉了哦:

表单:

{"[]": {"Comment": {}, //评论"User": {      //发布评论的用户"id@": "/Comment/userId" //User.id = Comment.userId}}
}

返回:

{"[]": [{"Comment": {"id": 3,"toId": 0,"userId": 82002,"momentId": 15,"date": "2017-02-01 19:20:50.0","content": "This is a Content...-3"},"User": {"id": 82002,"sex": 1,"name": "Happy~","tag": "iOS","head": "http://static.oschina.net/uploads/user/1174/2348263_50.png?t=1439773471000","contactIdList": [82005,82001,38710],"pictureList": [],"date": "2017-02-01 19:21:50.0"}},{"Comment": {"id": 4,"toId": 0,"userId": 38710,"momentId": 470,"date": "2017-02-01 19:20:50.0","content": "This is a Content...-4"},"User": {"id": 38710,"sex": 0,"name": "TommyLemon","tag": "Android&Java","head": "http://static.oschina.net/uploads/user/1218/2437072_100.jpg?t=1461076033000","contactIdList": [82003,82005],"pictureList": ["http://static.oschina.net/uploads/user/1218/2437072_100.jpg?t=1461076033000","http://common.cnblogs.com/images/icon_weibo_24.png"],"date": "2017-02-01 19:21:50.0"}}],"code": 200,"msg": "success"
}

还有动态 Moment 和它的点赞用户列表:

{"Moment": {},"User[]": {"User": {"id{}@": "Moment/praiseUserIdList" //id在点赞列表praiseUserIdList内}}
}

类似微信个人资料界面:

{"User": {},"Moment[]": { //朋友圈照片列表"Moment": {"@order":"date-", //按发布时间date倒序排列"userId@": "User/id"}}
}

类似微信朋友圈的动态列表:

{"[]": {"count": 3, //只要3个"page": 2,  //要第2页的"Moment": {},"User": {"id@": "/Moment/userId"},"Comment[]": {"Comment": {"momentId@": "[]/Moment/id"}}}
}

...

任意结构,任意内容,任意组合,

想要什么 JSON 结构、字段内容、表关联组合查询都可以完全自定义!

"key[]":{}                                         // 查询数组"key{}":[1,2,3]                                    // 匹配选项范围"key{}":"<=10,length(key)>1..."                    // 匹配条件范围"key()":"function(arg0,arg1...)"                   // 远程调用函数"key@":"key0/key1.../targetKey"                    // 引用赋值"key$":"%abc%"                                     // 模糊搜索"key?":"^[0-9]+$"                                  // 正则匹配"key+":[1]                                         // 增加/扩展"key-":888.88                                     // 减少/去除 "name:alias"                                      // 新建别名"@column":"id,sex,name"                           // 返回字段"@group":"userId"                                 // 分组方式"@having":"max(id)>=100"                          // 聚合函数"@order":"date-,name+"                            // 排序方式

以上都是查询请求,再试试 增删改 和 统计 :

增: http://apijson.cn:8080/post

{"Comment": {"userId": 82001,"momentId": 15,"content": "测试新增评论"},"tag": "Comment"
}

删: http://apijson.cn:8080/delete

{"Comment": {"id": 1510394480987},"tag": "Comment"
}

改: http://apijson.cn:8080/put

{"Comment": {"id": 22,"content": "测试修改评论"},"tag": "Comment"
}

批量删: http://apijson.cn:8080/delete

{"Comment": {"id{}": [1510394480987, 1510394804925]},"tag": "Comment[]"
}

批量改: http://apijson.cn:8080/put

{"Comment": {"id{}": [22, 114],"content": "测试批量修改评论"},"tag": "Comment[]"
}

统计: http://apijson.cn:8080/head

{"Comment": {"content$": "%测试%" //内容包含 测试 两个字}
}

写操作需要对应的权限,就是用 3 行代码配置的,请求报错:

登录后角色自动变为 LOGIN(可传@role 来自定义),符合 Comment 的 POST 权限配置,成功:

回想下,代码才写了 3 行,就实现了包括增删改查等各种操作的 8 个接口以及这么多种查询!

事实上用 APIJSON 根本就不用自己写接口!这 3 行代码其实是为了做权限管理!

像个人博客、非商业的新闻资讯网站这种可以没有权限控制的,

改下全局配置,不做权限校验,那就连一行代码都不用写了!!!

来源 | https://my.oschina.net/tommylemon/blog/1574430

热门内容:
  • 发现一款好用到爆的数据库工具,被惊艳到了!

  • 还在付费使用XShell?我选择这款国产良心工具,完全免费!

  • 八股文!让我收获了诸多offer~

  • 杭州程序员从互联网跳央企,晒一天工作和收入,网友:待一年就废

  • 别人家的公司的 1024 程序员节 ! 羡慕了!

最近面试BAT,整理一份面试资料《Java面试BAT通关手册》,覆盖了Java核心技术、JVM、Java并发、SSM、微服务、数据库、数据结构等等。
获取方式:点“在看”,关注公众号并回复 666 领取,更多内容陆续奉上。

明天见(。・ω・。)ノ♡

3行代码写出8个接口,开挂了?相关推荐

  1. 直击面试现场:神级程序员仅100秒,60行代码写出俄罗斯方块,成为全公司焦点!...

    小编我今天逛论坛看到一位HR帖子直播公司面试情况,该公司是做棋牌APP的,现在正在招聘前端工程师和运营人员,HR直播的是前端这块的,有写游戏的也有做网站项目的,写特效的都有很多,但是这位HR却看上了一 ...

  2. Python编曲实践(八):我,乔鲁诺·乔巴那,能用两百行代码写出JOJO黄金之风里我自己的出场曲!

    前言 前些天笔者写的文章 Python编曲实践(七):整整一百行Python代码写出黑人抬棺梗曲<Astronomia>的旋律 受到了大家的许多支持和好评,本篇文章挑战更复杂.更有挑战性, ...

  3. windows bat脚本编写_怎样在 txt 中用 2 行代码写出一个锁屏休息提醒脚本?

    锁屏 面对电脑,沉浸在工作中,往往忘记休息.长此以往,脊椎肯定受不了,造成驼背,对体态不好. 何不写一个小脚本,40 分钟锁一次屏,暗示你应该休息放松一下了? 新建 .txt 文档,命名随意,但后缀改 ...

  4. Pygame实战项目:用300行代码写出贪吃蛇小游戏

    贪吃蛇是一款逻辑清晰.操作简单.老少咸宜.备受欢迎的休闲小游戏. 下面就给大家介绍一下贪吃蛇游戏的基本原理,以及实现贪吃蛇所需要的相关方法. 一.主要思路 我们的贪吃蛇游戏将主要包括三个核心模块,分别 ...

  5. 【C语言】30行代码写出无限重启程序,室友太吵怎么办?

    目录 序 嗨,这里是狐狸~~ 基本思路

  6. 如何用 C++ 在 10 行内写出八皇后?

    bhuztez ,正在找工作 ... 韦易笑. RednaxelaFX. 小白菜. 钢盅郭子 等 517 人赞同 既然有人邀请我了,我就来了,解法参考 如何简化求解八妃问题的代码? - 知乎用户的回答 ...

  7. 如何用PYTHON代码写出音乐

    如何用PYTHON代码写出音乐 什么是MIDI 博主本人虽然五音不全,而且唱歌还很难听,但是还是非常喜欢听歌的.我一直在做这样的尝试,就是通过人工智能算法实现机器自动的作词和编曲(在这里预告下,通过深 ...

  8. [教你做小游戏] 用86行代码写一个联机五子棋WebSocket后端

    我是HullQin,公众号线下聚会游戏的作者(欢迎关注公众号,发送加微信,交个朋友),转发本文前需获得作者HullQin授权.我独立开发了<联机桌游合集>,是个网页,可以很方便的跟朋友联机 ...

  9. Java复习题1(1.写出抽象类和接口的区别。2.This和Super关键字的区别有哪些?3.常见的类集子类有哪些,各有什么特点?4.什么是多态,多态实现的前提是什么?)

    1.写出抽象类和接口的区别. 答: 抽象类中的方法不全是抽象方法,可以在抽象类中声明并实现其他方法. 接口不允许方法的实现,定义的方法无方法体. 抽象类中的成员变量可以使用不同修饰符修饰,如publi ...

最新文章

  1. 让Hinton后悔投少了的AI公司:吴恩达弟子创办,李飞飞也是投资人
  2. Mysql 主从复制(AB复制)
  3. Java 斐波那契数列
  4. Three.js入门
  5. 17 年安全界老兵,专注打造容器安全能行吗?
  6. 九年级数学解方程50道_初中数学公式中考知识点总结,初三数学上册,九年级数学上册...
  7. 计算机研究生进中国银行,听说中行笔试把研究生学姐都难哭了…
  8. 孙鑫VC学习笔记:第十四讲 (二) 网络编程
  9. 深入探討 SCOM 2007 管理技術
  10. Kubernetes v1.14.0 之 kube_scheduler 部署
  11. SQL注入不完全思路与防注入程序
  12. 同构 JavaScript 应用开发
  13. assume用法及意思_assume用法及例句
  14. G码云+hexo搭建博客
  15. Excel中文转拼音(完整版)-转
  16. HTTP 协议的演变历程
  17. WIN8 与WIN7的64位及32位 分别对Legacy BIOS+MBR和UEFI+GPT两种启动方式和分区架构下的安装可行性分析
  18. PlantUML 之时序图
  19. 什么是java集合,java集合有几类?
  20. 3dmax2014植树插件_3DsMax种树插件:ForestPack Pro v6.1.2 For 2015-2019 updated Libraries

热门文章

  1. C++数值极限numeric_limits
  2. 链接2: excel中的截取文子串的功能------left,mid以及right函数使用
  3. 10.matlab中sort , min/max以及ceil 函数
  4. MySQL的information_schema
  5. mac终端命令-----常规操作
  6. 测试用例设计白皮书--正交实验设计方法
  7. 数据库中存储与读取文件
  8. 从网页模版切图到网页生成全攻略(转)
  9. 【青少年编程】【一级】舞者凯希
  10. Matlab与线性代数 -- 线性间隔向量