说到接口开发,能想到的开发语言有很多种,像什么Java啊、.NET啊、PHP啊、NodeJS啊,太多可以用。为什么选择Java,究其原因,最后只有一个解释,那就是“学Java的人多,人员招聘范围大,有利于团队扩建”。真要说说效率的话,恕我直言,真不如NodeJS(其他的.NET、PHP我不会,O(∩_∩)O~~)。

言归正传,基于Java的框架很多,最终选择了SpringBoot(中间的过程就不说了,折磨了我2天),我们要实现的主要目标,一句话概括“收到前端发送的API接口请求,完成数据以及逻辑处理,返回结果数据”。

一、创建基础工程

1. 打开IDEA -> File -> New -> Project...

创建完工程以后,大概就是上面这个模样(别着急继续,等你的Maven把依赖库下载完,再继续下面的。如果你连Maven都没安装的话,先自行百度把Maven配置好)。

二. 创建项目目录

(庆幸一口气在图片上都标注号了)

多说一句,目录结构,完全可以根据自己的项目需要重新归置,毕竟自己用的顺手才是最重要的。

三、接下来写个样例

controller/Test

package com.univalsoft.springbootapimaster.api.controller;

import com.univalsoft.springbootapimaster.common.controller.BaseController;
import com.univalsoft.springbootapimaster.common.model.APIResponse;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController; @RestController
public class Test extends BaseController { @RequestMapping(value = "/api/test/try", method = RequestMethod.POST)
public APIResponse uploadImage(
@RequestParam(value = "name") String name /* 姓名 */
) { //
if (name.length() < 3) {
return this.fail("[姓名]参数不合法,请重新输入");
} String result = name + ", 欢迎浏览,转载请注明出处!!!(Univalsoft)";
return this.success(result);
}
}

如此简单的代码,就不多说了哈,看不懂的,自觉找个墙角面壁。

运行程序,have a try !

几个重要的基类

1. BaseController

package com.univalsoft.springbootapimaster.common.controller;

import com.univalsoft.springbootapimaster.common.model.APIResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.RestController; import java.util.HashMap; @RestController
public class BaseController { public final Logger logger = LoggerFactory.getLogger(this.getClass()); /**
* 返回成功Response
*
* @param data
* @return
*/
public APIResponse success(Object data) {
logger.info("请求结束 :success: =>", data.toString());
APIResponse res = new APIResponse();
res.success(data);
return res;
} /**
* 分页列表
*
* @param data
* @param pageIndex
* @param pageSize
* @param total
* @return
*/
public APIResponse successWithPage(Object data, int pageIndex, int pageSize, int total) {
logger.info("请求结束 :success: =>", data.toString());
APIResponse res = new APIResponse(); HashMap<String, Object> pageResponse = new HashMap<>();
pageResponse.put("data", data);
pageResponse.put("current", pageIndex);
pageResponse.put("hasMore", pageIndex * pageSize < total);
pageResponse.put("total", total); res.success(pageResponse);
return res;
} /**
* 返回错误Response
*
* @param errmsg
* @return
*/
public APIResponse fail(String errmsg) {
logger.info("请求结束 :fail: =>", errmsg);
APIResponse res = new APIResponse();
res.fail(1, errmsg);
return res;
} }

 

2. APIResponse

package com.univalsoft.springbootapimaster.common.model;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List; public class APIResponse { /**
*
*/
private static final long serialVersionUID = 1L; public static final int ERROR_PARAM_INVALID = 40001;
public static final int ERROR_AUTH_FAIL = 44001; // 认证信息失败 // 信息代码
private int errno;
// 返回信息
private String errmsg;
// 返回内容
private Object data; /**
* 返回错误信息
* @param errno
* @param errmsg
*/
public void fail(int errno, String errmsg) {
this.errno = errno;
this.errmsg = errmsg != null ? errmsg : "";
this.data = ""; // 整体错误
if (errno == ERROR_PARAM_INVALID) {
this.errmsg = "参数不合法";
} else if (errno == ERROR_AUTH_FAIL) {
this.errmsg = "信息认证失败";
}
} /**
* 分页数据查询
*
* @param list 业务数据集合
* @param count 总条数
* @param current 当前页码
* @param pageSize 每页数量
*/
public void setPageData(List list, Integer count, Integer current, Integer pageSize) { HashMap<String, Object> data = new HashMap<>();
data.put("totalAmount", count); // 符合条件的总条数
data.put("current", current); // 当前页码
data.put("amount", (count + pageSize - 1) / pageSize); // 总页数(向上取整) // 容错数组类型
if (list != null) {
data.put("data", list); // 业务数据
} else {
data.put("data", new ArrayList<>()); // 空业务数据
} this.data = data;
} /**
* 返回成功信息
* @param data
*/
public void success(Object data) {
this.errno = 0;
this.errmsg = "";
this.data = data;
} public int getErrno() {
return errno;
} public void setErrno(int errno) {
this.errno = errno;
} public String getErrmsg() {
return errmsg;
} public void setErrmsg(String errmsg) {
this.errmsg = errmsg;
} public Object getData() {
return data;
} public void setData(Object data) {
this.data = data;
}
}

  

好了,基础工程完活。

接口开发-基于SpringBoot创建基础框架的更多相关文章

  1. 封装:简要介绍自定义开发基于WPF的MVC框架

    原文:封装:简要介绍自定义开发基于WPF的MVC框架 一.目的:在使用Asp.net Core时,深感MVC框架作为页面跳转数据处理的方便,但WPF中似乎没有现成的MVC框架,由此自定义开发一套MVC ...

  2. 基于springboot的SSM框架实现返回easyui-tree所需要数据

    1.easyui-tree easui-tree目所需要的数据结构类型如下: [ { "children": [ { "children": [], " ...

  3. PHP扩展开发(1)-创建基础框架

    生成PHP扩展开发的基础框架.   一.Linux下   $>cd ~/{php源码}/ext $>./ext_skel --extname=simple   Creating direc ...

  4. 如莲开发平台(MIS基础框架、Java技术、B/S结构)

    关于     「如莲」是一套MIS类系统基础框架,主要用于各类“管理信息系统”的开发,也适合做网站后台开发.可省去开发时的框架搭建.规范约定.权限管理等基础工作,直接专注于业务功能实现.     「如 ...

  5. 使用vue+elementUI+springboot创建基础后台增删改查的管理页面--(1)

    目前这家公司前端用的是vue框架,由于在之前的公司很少涉及到前端内容,对其的了解也只是会使用js和jquery,所以..慢慢来吧. 在此之前需要先了解vue的大致语法和规则,可先前往官方文档进行学习h ...

  6. 微信开发基于springboot

    0.申请一个微信公众号,记住他的appId,secret,token,accesstoken 1.创建一个springboot项目.在pom文件里面导入微信开发工具类 <dependency&g ...

  7. 使用PHP做移动端 api接口开发方法(适用于TP框架)

    1. [代码]使用TP框架时 放在common文件夹下文件名就叫function.php ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 ...

  8. Yii2 advanced版API接口开发 基于RESTful架构的 配置、实现、测试

    参考地址: http://www.xiaoxiangzi.com/Programme/PHP/3348.html http://www.cnblogs.com/ganiks/p/yii2-restfu ...

  9. 从SpringBoot到SpringCloudAlibaba简明教程(一):初识SpringBoot及其基础项目构建

    前言 Spring框架的大名想必大家早已如雷贯耳,我们来看一下springboot诞生的初衷,以及它在springframe的基础上解决了哪些痛点. 很久以前,J2EE还是java企业级应用的标准规范 ...

随机推荐

  1. html5 canvas 圆形径向渐变

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. MongoDB 之 Limit 选取 Skip 跳过 Sort 排序 MongoDB - 7

    我们已经学过MongoDB的 find() 查询功能了,在关系型数据库中的选取(limit),排序(sort) MongoDB中同样有,而且使用起来更是简单 首先我们看下添加几条Document进来 ...

  3. kali的中文输入法-安装后无中文选项的解决办法

    我在我实体电脑上安装了kali 本想安装个中文输入法但是有时候输入发中根本没有选择输入法的这一项.所以导致很别扭,之前在虚机上安装过没有问题但是挪到实体机上就是没有用的也是fcitx,这一度让我这个小 ...

  4. 简单解读linux的/proc下的statm、maps、memmap 内存信息文件分析【转】

    转自:https://blog.csdn.net/sctq8888/article/details/7398776 转载自:http://hi.baidu.com/deep_pro/blog/item ...

  5. Linux 串口、usb转串口驱动分析(2-1) 【转】

    转自:http://blog.chinaunix.net/xmlrpc.php?r=blog/article&uid=26807463&id=4186851 Linux 串口.usb转 ...

  6. 打包部署到tomcat

    部署到tomcat的方法 注意:在eclipse 或 idea 上需要引入外部tomcat 1.将程序打成war包启动tomcat 2.将target 文件下内容压缩城zip,发布到tomcat RO ...

  7. 爬虫、框架scrapy

    阅读目录 一 介绍 二 安装 三 命令行工具 四 项目结构以及爬虫应用简介 五 Spiders 六 Selectors 七 Items 八 Item Pipeline 九 Dowloader Midd ...

  8. python2.x下pip install mysql-python报错解决办法

    在https://www.lfd.uci.edu/~gohlke/pythonlibs/#mysql-python 下载该驱动网盘链接:https://pan.baidu.com/s/1r0fNYnU ...

  9. Ubuntu18.04安装和配置 Java JDK 和 JRE,并卸载自带OpenJDK

    https://blog.csdn.net/freeking101/article/details/80522586

  10. Codeforces 463D Gargari and Permutations(求k个序列的LCS)

    题目链接:http://codeforces.com/problemset/problem/463/D 题目大意:给你k个序列(2=<k<=5),每个序列的长度为n(1<=n< ...