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

Javaweb—Ajax与jQuery请求

文章目录

  • 十一.Javaweb—Ajax与jQuery请求
    • 11.1 异步/同步请求
    • 11.2 异步请求案例
      • 案例一:
      • 案例二:

十一.Javaweb—Ajax与jQuery请求

Ajax: 全称Asynchronous JavaScript And XML,异步的JavaScript和XML。

11.1 异步/同步请求

【往期文章】

  • 同步请求发送:

浏览器页面在发送请求给服务器,在服务器处理请求的过程中,浏览器页面不能做其他的操作。只能等到服务器响应结束后才能,浏览器页面才能继续做其他的操作。

  • 异步交互:

可以在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页的技术,如:搜索联想、用户名是否可用的校验等等。

11.2 异步请求案例

案例一:

前端页面:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<h1>未登录</h1>
<button>登录</button>

</body>
</html>
<script src="/js/jquery-1.10.2.min.js"></script>
<script>

    $(function () {
        var str = "kwh"
        $("button").click(function () {
            $.ajax({
                url: "/ajax",
                // data: "username=admin&password=123",
                //传递json格式数据
                data:{"username":"admin","password":123},
                async: true, // true 异步, false 同步
                tpype: "get",
                datetype: "json",
                success: function (res) {
                    alert(res);
                    $("h1").text(res);
                },
                error: function () {
                    alert("not_login is error");
                }
            });
           // 异步执行 先弹出alert(str) 再执行alert(res)
            alert(str);

        });
    });
</script>

后端服务:

@WebServlet("/ajax")
public class AjaxServlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String res = "";
        //获取前端提交的参数
        String username = request.getParameter("username");
        String password = request.getParameter("password");

    if(username.equals("admin") && password.equals("123")) {
           res = "登录成功";
        }

        response.setCharacterEncoding("UTF-8");
        response.getWriter().write(res);
    }
}

案例二:

统一响应结果:

import com.alibaba.fastjson.JSONObject;
public class ResultJSON {
    private Integer code;
    private String msg;

    public ResultJSON(Integer code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    public String jsonString(){
       return new JSONObject().toJSONString(this);
    }

    public static ResultJSON success(){
        return new ResultJSON(200,"登录成功");
    }
  
  public static ResultJSON success(Integer code,String msg){
        return new ResultJSON(code,msg);
    }
  
    public static ResultJSON error(){
        return new ResultJSON(400,"登录失败");
    }
    public static ResultJSON error(Integer code,String msg){
        return new ResultJSON(code,msg);
    }

    public Integer getCode() {
        return code;
    }

    public void setCode(Integer code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }
}

前端页面:

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>

<h1>未登录</h1>
<button>登录</button>

</body>
</html>
<script src="/js/jquery-1.10.2.min.js"></script>
<script>
    $(function () {
        $("button").click(function () {
            $.ajax({
                url: "/ajax02",
                // data: "username=admin&password=123",
               //传递json格式数据
                data:{"username":"admin","password":"123"},
                async: true, // true 异步, false 同步
                tpype: "get",//使用的请求类型
                datetype: "json",//响应回来的数据类型
                success: function (res) {
                    alert(res);
                    $("h1").text(res);
                },
                error: function () {
                    alert("not_login is error");
                }
            });

        });

    });
</script>

后端服务

@WebServlet("/ajax02")
public class Ajax02Servlet extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String res = "";
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        response.setCharacterEncoding("UTF-8");

        PrintWriter writer = response.getWriter();

     if("admin".equals(username)&& "123".equals(password)) {
           writer.write(ResultJSON.success().jsonString());
        }else {
            writer.write(ResultJSON.error().jsonString());
        }
        // response.getWriter().write(res);
    }
}

http://www.kler.cn/a/393913.html

相关文章:

  • Flink源码解析之:Flink on k8s 客户端提交任务源码分析
  • C语言的语法
  • QT c++ 按钮 样式 设置按下和松开的背景颜色
  • Freemarker模板进行判空
  • Apache Celeborn 在B站的生产实践
  • 【C++】字符串与字符数|组操作详解:strcpy 和 strcat 的使用与解析
  • PostgreSQL 事务读取行 不使用行锁 真的? 利弊双刃剑
  • SpringBoot技术栈:构建高效共享汽车系统
  • PAT甲级 1097 Deduplication on a Linked List(25)
  • 稀硫酸介质中 V 型球阀的材质选择与选型要点-耀圣
  • C++ | Leetcode C++题解之第552题学生出勤记录II
  • [ 网络安全开源项目 ] 市面上常见的开源 HIDS 有哪些 ?
  • 计算机视觉中的中值滤波:经典案例与Python代码解析
  • centos7上安装mysql
  • 分享 pdf 转 word 的免费平台
  • Rust 语言学习笔记(二)
  • Django基础用法+Demo演示
  • 2025年软考高项论文该怎么备考与复习?
  • 遥感大数据智能分析与应用
  • vue2和vue3的区别详解
  • 『VUE』25. 组件事件与v-model(详细图文注释)
  • web安全漏洞之ssrf入门
  • Spring MVC练习
  • 【python】python使用虚拟环境
  • C++初阶:类和对象(上)
  • Golang | Leetcode Golang题解之第563题二叉树的坡度