当前位置: 首页 > news >正文

SpringMVC练习:加法计算器与登录

加法计算器

        需求分析

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

        接口定义与请求的参数

        请求路径:calc/add,请求方式:GET/POST.

        请求参数:num1:类型Integer,必传参数;num2:类型Integer,必传参数.

        后端代码

        仅需要接收前端传来的两个num1与num2参数,然后将计算机过返回即可.

@RestController
@RequestMapping("/calc")
public class Calc {@RequestMapping("/add")public String add(Integer num1, Integer num2) {Integer sum = num1 + num2;return "<h1>计算结果:"+sum+"</h1>";}
}

        前端代码

<!DOCTYPE html>
<html lang="zh-CN">
<head><meta charset="UTF-8"><title>加法计算器</title>
</head>
<body>
<form action="calc/add" method="post"><h1>计算器</h1>数字1:<input name="num1" type="text"><br>数字2:<input name="num2" type="text"><br><input type="submit" value=" 点击相加">
</form>
</body>

        运行结果:

        访问127.0.0.1:8080/calc.html,输入要计算的数字,点击提交.

        结果符合预期.

用户登录

        需求分析

        用户输入账号与密码,后端检验账号与密码是否正确.

        如果正确,跳转页面.如果不正确,提示账号或密码错误.如果用户已登录,则返回用户已登录.

        接口定义与请求的参数

        登录请求路径:/user/login,请求方式POST.

        登录请求参数:userName:类型String,必传参数;password:类型String,必传参数.

        查询用户是否登录路径:/user/getLoginUser

        后端代码

        两个方法,一个用于登录,一个用于查询用户是否登录.判断用户是否登录方法:在session中添加登陆过的用户的用户名,如果查询session中没有用户名,则用户没有登陆过.

@RestController
@RequestMapping("/user")
public class Login {@RequestMapping("/login")public boolean login(String userName, String password,HttpSession session) {//判断账号密码是否为空if(!StringUtils.hasLength(userName) || !StringUtils.hasLength(password)) {//为空 返回falsereturn false;}//判断账号密码是否正确,这里账号密码都取adminif(userName.equals("admin") && password.equals("admin")) {//设置session,方便后续查询用户是否登录session.setAttribute("userName", "admin");return true;}return false;}@RequestMapping("/getLoginUser")public String getLoginUser(@SessionAttribute("userName") String userName) {if(StringUtils.hasLength(userName)) {//用户已登录return userName;}//用户未登录return "";}
}

        前端代码

<!doctype html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport"content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>用户登录首页</title>
</head><body>
登录人: <span id="loginUser"></span><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js"></script>
<script>$.ajax({type: "get",url: "/user/getLoginUser",success: function (result) {$("#loginUser").text(result);}});
</script>
</body>
</html>
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><title>登录页面</title>
</head><body>
<h1>用户登录</h1>
用户名:<input name="userName" type="text" id="userName"><br>
密码:<input name="password" type="password" id="password"><br>
<input type="button" value="登录" onclick="login()"><script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js"></script>
<script>function login() {$.ajax({type: "post",url: "/user/login",data: {"userName": $("#userName").val(),"password": $("#password").val()},success: function (result) {if (result) {location.href = "/index.html"} else {alert("账号或密码有误.");}}});}</script>
</body></html>

        运行结果

        访问页面,输入账号密码,观察正确或错误的提示,并再次访问页面.

        输入错误的账号密码.

        输入正确的账号密码:

        离开网页再次访问:

 

http://www.dtcms.com/a/481731.html

相关文章:

  • 小模型的应用
  • 深度学习进阶(一)——从 LeNet 到 Transformer:卷积的荣光与注意力的崛起
  • QPSK信号载波同步技术---极性Costas 法载波同步
  • 盘多多网盘搜索苏州seo排名公司
  • 国外有趣的网站wordpress小视频主题
  • RTC、UDP、TCP和HTTP以及直播等区别
  • Java面试场景:从Spring Web到Kafka的音视频应用挑战
  • 基于EDBO-ELM(改进蜣螂算法优化极限学习机)数据回归预测
  • gaussdb数据库的集中式和分布式
  • Ubuntu中使用Hadoop的HDFS和MapReduce
  • F024 RNN+Vue+Flask电影推荐可视化系统 python flask mysql 深度学习 echarts
  • Building-GAN模型结构详解
  • web开发,学院培养计划系统,基于Python,FlaskWeb,Mysql数据库
  • 三维旋转矩阵的左乘与右乘
  • c 网站开发数据库连接网站扫码充值怎么做的
  • 第三方媒体流压力测试:k6插件xk6-webrtc的使用来测试媒体流的性能
  • 综合门户媒体发稿哪家靠谱
  • iis网站属性没有asp.net微信订阅号做微网站
  • 【Nest】权限管理——RBAC/CASL
  • 使用LSTM进行人类活动识别
  • 列表标签之有序标签(本文为个人学习笔记,内容整理自哔哩哔哩UP主【非学者勿扰】的公开课程。 > 所有知识点归属原作者,仅作非商业用途分享)
  • AI时代BaaS | 开源的后端即服务(BaaS)平台Supaba
  • 达梦存储结构篇
  • 桂林网站制作网站佛山公共交易资源平台
  • 域名验证网站如何找推广平台
  • 日语学习-日语知识点小记-构建基础-JLPT-N3阶段-二阶段(1):文法運用
  • C++面向对象进阶:从构造函数到static成员
  • python3GUI--模仿百度网盘的本地文件管理器 By:PyQt5(详细分享)
  • Go 1.21 新特性:context.AfterFunc 的实用指南
  • Acer软件下载