相关推荐recommended
【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录
作者:mmseoamin日期:2024-01-19

文章目录

  • 🎍序言
  • 🌳加法计算器
    • 🚩准备工作
    • 🚩约定前后端交互接⼝
    • 🌲后端服务器代码的书写
    • 🌴用户登录
      • 🚩效果展示
      • 🚩准备工作
      • 🚩约定前后端交互接⼝
        • 🎈需求分析
        • 🎈接⼝定义
          • 📌校验接⼝
          • 📌查询登录⽤⼾接⼝
          • 🚩后端代码的书写
            • 🎈校验接⼝代码
            • 🎈查询登录⽤⼾接⼝
            • 🎈完整代码实现
            • ⭕总结

              🎍序言

              本篇博客主要内容:

              1. 理解前后端交互过程

              2. 接⼝传参,数据返回,以及⻚⾯展⽰

              🌳加法计算器

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

              效果展示如下:

              【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第1张

              【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第2张

              具体实现步骤,博主大致分为以下几步:

              1. 准备工作

              2. 约定前后端交互接⼝

              3. 后端服务器代码的书写

              🚩准备工作

              创建SpringBoot项⽬: 引⼊Spring Web依赖

              这部分不会的小伙伴可以去看看博主写的【JavaEE进阶】 SpringBoot的创建与简单使用

              创建calc.html文件

              【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第3张

              接下来我会直接给出大家前端的代码,大家直接导入即可,前端代码如下:

              
              
              
                  
                  Title
              
              
              

              计算器

              数字1:
              数字2:

              🚩约定前后端交互接⼝

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

              接⼝⼜叫API(Application Programming Interface),我们⼀般讲到接⼝或者API,指的都是同⼀个东西.

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

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

              现在"前后端分离"模式开发,前端和后端代码通常由不同的团队负责开发.双⽅团队在开发之前,会提前约定好交互的⽅式.客⼾端发起请求,服务器提供对应的服务.

              服务器提供的服务种类有很多,客⼾端按照双⽅约定指定选择哪⼀个服务

              接⼝,其实也就是我们前⾯⽹络模块讲的的"应⽤层协议".把约定的内容写在⽂档上,就是"接⼝⽂档",接⼝⽂档也可以理解为是应⽤程序的"操作说明书

              在项⽬开发前,根据需求先约定好前后端交互接⼝,双⽅按照接⼝⽂档进⾏开发.

              • 接⼝⽂档通常由服务提供⽅来写,交由服务使⽤⽅确认,也就是客⼾端.

              • 接⼝⽂档⼀旦写好,尽量不要轻易改变.

              • 如若需要改变,必须要通知另⼀⽅知晓

                接下来我们一起来写一个关于加法计算器的简单的接口文档

                首先我们进行需求分析

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

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

                  请求路径:calc/sum

                  请求⽅式:GET/POST

                  接⼝描述:计算两个整数相加

                  对于所传参数我们也需要进行规定

                  参数名类型是否必须备注
                  num1Integer参与计算的第⼀个数
                  num2Integer参与计算的第⼆个数

                  最后我们对于响应数据的格式也进行规定

                  Content-Type: text/html

                  响应内容:例如:计算结果为:23+25=48

                  🌲后端服务器代码的书写

                  基于接口文档我们就直接书写了

                  后端代码如下:

                  package org.example.smallprojects.demos.web;
                  import org.springframework.web.bind.annotation.RequestMapping;
                  import org.springframework.web.bind.annotation.RestController;
                  @RequestMapping("/calc")
                  @RestController
                  public class CalcController {
                      @RequestMapping("/sum")
                      public String sum(Integer num1,Integer num2) {
                          Integer sum = num1 + num2;
                          return "

                  计算结果为:"+num1 + "+" + num2 + "=" + sum +"

                  "; } }

                  注意:

                  • 返回数据类型与传入参数名一定要与接口文档相对应

                    接下里直接访问:http://127.0.0.1:8080/calc.html

                    🌴用户登录

                    🚩效果展示

                    登录校验展示:

                    【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第4张

                    登录后获取用户名展示;

                    【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第5张

                    实现步骤依旧三步走

                    🚩准备工作

                    这里博主依旧给出前端代码

                    【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录,在这里插入图片描述,第6张

                    index.html代码如下:

                    
                    
                    
                        
                        
                        
                        用户登录首页
                    
                    
                    登录人: 
                    
                    
                    

                    longin.html代码如下:

                    
                    
                    
                        
                        登录页面
                    
                    
                    

                    用户登录

                    用户名:
                    密码:

                    🚩约定前后端交互接⼝

                    🎈需求分析

                    对于后端开发⼈员⽽⾔,不涉及前端⻚⾯的展⽰,只需要提供两个功能

                    1. 登录⻚⾯: 通过账号和密码,校验输⼊的账号密码是否正确,并告知前端
                    2. ⾸⻚:告知前端当前登录⽤⼾.如果当前已有⽤⼾登录,返回登录的账号,如果没有,返回false

                    🎈接⼝定义

                    该功能设计两个页面,所以这里我们定义两个接口

                    📌校验接⼝

                    请求路径:/user/login

                    请求⽅式:POST

                    接⼝描述:校验账号密码是否正确

                    • 请求参数
                      参数名类型是否必须备注
                      userNameString校验的账号
                      passwordString校验的密码
                      • 响应数据

                        Content-Type: text/html

                        响应内容:

                        • true //账号密码验证成功
                        • false//账号密码验证失败
                        📌查询登录⽤⼾接⼝

                        请求路径:/user/getLoginUser

                        请求⽅式:GET

                        接⼝描述:查询当前登录的⽤⼾

                        • 请求参数

                          • 响应数据

                            Content-Type: text/html

                            响应内容:遇事问春风乄

                            🚩后端代码的书写

                            🎈校验接⼝代码

                            校验我们首先需要进行判断用户名与密码是否为空或者长度为0,若为,则返回false。

                            这里我们选择使用StringUtils.hasLength()来判断,StringUtils.hasLength()是Spring提供的⼀个⼯具⽅法,判断字符串是否有值字符串为null或者""时,返回false,其他返回true

                            其次由于我们这里并没有添加数据库,所以我们直接使用固定的字符串进行判断。

                            如果用户名与密码正确,则将该用户添加至session,对session不了解的小伙伴可以看看博主写的【JavaEE进阶】 获取Cookie和Session

                            🎈查询登录⽤⼾接⼝

                            对于该接口实现就更加加简单了。直接使用@SessionAttribute进行获取即可

                            🎈完整代码实现

                            package org.example.smallprojects.demos.web;
                            import org.springframework.util.StringUtils;
                            import org.springframework.web.bind.annotation.RequestMapping;
                            import org.springframework.web.bind.annotation.RestController;
                            import org.springframework.web.bind.annotation.SessionAttribute;
                            import javax.servlet.http.HttpSession;
                            @RestController
                            @RequestMapping("/user")
                            public class LoginController {
                                @RequestMapping("/login")
                                public Boolean login(String userName, String password, HttpSession session) {
                                    if(!StringUtils.hasLength(userName) || !StringUtils.hasLength(password)) {
                                        return false;
                                    }
                                    if("遇事问春风乄".equals(userName)&&"666666".equals(password)) {
                                        //密码验证成功, 把⽤⼾名存储在Session中
                                        session.setAttribute("userName",userName);
                                        return true;
                                    }
                                    return false;
                                }
                                @RequestMapping("getLoginUser")
                                public String getLoginUser(@SessionAttribute(value = "userName",required = false) String username) {
                                    return username;
                                }
                            }
                            

                            ⭕总结

                            关于《【JavaEE进阶】 利用Spring简单实现加法计算器和用户登录》就讲解到这儿,感谢大家的支持,欢迎各位留言交流以及批评指正,如果文章对您有帮助或者觉得作者写的还不错可以点一下关注,点赞,收藏支持一下!