【SpringMVC】深入解析 API 概念及接口定义方法和 SpringMVC 综合实战—简单加法计算器


综合性练习


  • 理解前后端交互过程
  • 接口传参,数据返回,以及页面展示

加法计算器


需求:输入两个整数,点击"点击相加"按钮,显示计算结果


使用Postman来发送****JSON 请求参数


1. 准备工作


创建SpringBoot项目:引入Spring Web依赖,把前端页面放在项目中

码云地址: JavaEE进阶课程资料包

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
     <form action="calc/sum" method="post">
        <h1>计算器</h1>
        数字1:<input name="num1" type="text"><br>
        数字2:<input name="num2" type="text"><br>
        <input type="submit" value=" 点击相加 ">
    </form>
</body>

</html>

2. 约定前后端交互接口


2.1 概念介绍


约定"前后端交互接口"是进行 Web 开发中的关键环节。

接口又叫 API(Application Programming Interface),我们一般讲到接口或者 API,指的都是同一个东西。

是指应用程序对外提供的服务的描述,用于交换信息执行任务(与JavaSE阶段学习的[类和接口]中的接口是两回事)。

简单来说,就是允许客户端给服务器发送哪些 HTTP 请求,并且每种请求预期获取什么样的 HTTP 响应。


现在"前后端分离"模式开发,前端和后端代码通常由不同的团队负责开发。

双方团队在开发之前,会提前约定好交互的方式

客户端发起请求,服务器提供对应的服务。

服务器提供的服务种类有很多,客户端按照双方约定指定选择哪一个服务。

接口,其实也就是我们前面网络模块讲的"应用层协议"

约定的内容写在文档上,就是"接口文档",接口文档也可以理解为是应用程序的"操作说明书"

比如儿童电话玩具

  • 按1:响应儿歌
  • 按2:响应钢琴乐曲
  • 按3:安抚睡眠
  • 按4:交通工具音效
    ...

但是这些操作说明,如果没有一个文档来说明,用户就不太清楚哪个按键对应哪个,所以商品一般会带一个说明书。

  • 这些按键,就是接口
  • 这个"说明书",就是应用程序的"接口文档"。

在项目开发前,根据需求先约定好前后端交互接口,双方按照接口文档进行开发。

  • 接口文档通常由服务提供方来写,交由服务使用方确认,也就是客户端
  • 接口文档一旦写好,尽量不要轻易改变。
  • 如若需要改变,必须要通知另一方知晓。

2.2 需求分析


加法计算器功能,对两个整数进行相加,需要客户端提供参与计算的两个数,服务端返回这两个整数计算的结果。

基于以上分析,我们来定义接口。


2.3 接口定义



2.4 请求参数


示例:num1=5 & num2=3


2.5 响应数据


服务器给浏览器返回计算的结果


3. 服务器代码



java 复制代码
package com.example.springmvc_demo;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RequestMapping("/calc")
@RestController
// @RestController 表示返回数据, @Controller 表示返回视图

public class CalcController {
    @RequestMapping("/sum")
    public String sum(Integer num1 , Integer num2){
        if(num1 == null || num2 == null){
            return "参数不合法,请检查和再提交";
        }
        Integer sum = num1 + num2;
        return "<h1>计算机计算结果: " + sum + "</h1>";
    }
}

运行程序,使用 Postman 发送请求:




4. 调整前端页面代码


添加访问 url请求方式

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
     <form action="calc/sum" method="post">
        <h1>计算器</h1>
        数字1:<input name="num1" type="text"><br>
        数字2:<input name="num2" type="text"><br>
        <input type="submit" value=" 点击相加 ">
    </form>
</body>

</html>

5. 运行测试


启动服务,运行并测试: http://127.0.0.1:8080/calc.html 注意路径;


相关推荐
thePLJ19 分钟前
SpringBoot-已添加并下载的依赖,reload和mvn clean 后还是提示找不到jar包问题
java·spring boot·后端
宋发元21 分钟前
Java 代理模式详解
java·开发语言
余华余华22 分钟前
输入输出 数组 冒泡排序举例
java·后端
hxung37 分钟前
spring bean的生命周期和循环依赖
java·后端·spring
油丶酸萝卜别吃41 分钟前
springBoot中不添加依赖 , 手动生成一个token ,并校验token (使用简单 , 但是安全会低一点)
spring boot·后端·安全
酷爱码43 分钟前
Java分布式常提到的面试题包含答案
java·开发语言·分布式
Hsuna1 小时前
一句配置让你的小程序自动适应Pad端
前端·javascript
Seven971 小时前
深入探索java.util.Objects工具类
java
渔樵江渚上1 小时前
玩转图像像素:用 JavaScript 实现酷炫特效和灰度滤镜
前端·javascript·面试
陆康永1 小时前
uniapp-x vue 特性
javascript·vue.js·uni-app