Java学习(AJAX,JSON,案例:校验用户名是否存在)

2022/3/25

一、AJAX
1.概念:异步的javaScript和XML
        1.异步和同步:客户端和服务器端相互通信的基础上
                * 客户端必须等待服务器端的响应。在等待的期间客户端不能做其他操作就是同步
                * 客户端不需要等待服务器端的响应。在服务器处理请求的过程,客户端可以进行其他操作是异步
                Ajax是一种在无需重新加载整个页面的情况下,能够更新部分网页的技术
                通过在后台与服务器进行少量的数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
                传统的网页不适用Ajax,如果需要更新内容,必须重载整个网页页面。
                提升用户的体验
2.实现
        1.JQuery实现方式
                1.$.ajax()

package ln.webtest.day01.Servlet;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/ajaxServlet")
public class AjaxServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.获取请求参数
        String username = request.getParameter("username");
        //2.打印username
        System.out.println(username);
        //3.响应
        response.getWriter().write("hello:"+username);
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>异步</title>
    <script src="js/jquery.min.js"></script>
    <script>
        //定义方法
        function fun(){
            //使用$.ajax()发送异步请求
            $.ajax({
                url:"ajaxServlet", //请求路径
                type:"POST",  //默认是GET
                data:"username=jack&age=23",  //请求参数
                //data:{"username":"jack"},
                success:function (data){  //这里的date是接收响应服务器的数据
                    alert(data);
                },   //响应成功后的回调函数
                error:function (){
                    alert("出错啦...")
                },  //表示如果请求响应出现错误,会执行的回调函数
                dataType:"text"  //设置接受到的响应数据的格式
                //最后一个键值对结束最好不要加逗号,加上也不会报错
            });
        }
    </script>
</head>
<body>
    <input type="button" value="发送异步请求" onclick="fun();">
</body>
</html>

                 2.$.get():发送get请求
                       * 语法:$.get(url,[data],[callback],[type])
                                * 参数:
                                        * url:请求路径
                                        * data:请求参数
                                        * callback:回调函数
                                        * type:响应结果的类型
                3.$.post():发送post请求

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>异步</title>
    <script src="js/jquery.min.js"></script>
    <script>
        
        function fun(){
            $.post("ajaxServlet","username=jack",function(data){  //get一样
                alert(data)
            },"text");
        }
    </script>
</head>
<body>
    <input type="button" value="发送异步请求" onclick="fun();">
</body>
</html>

二、JSON:
1.概念:JavaScript对象表示法
        var p = {"name":"张三","age":23,"gender":"男"};
        * json现在多用于存储和交换文本信息的语法
        * 进行数据的传输
        * JSON比XML更小,更快,更易解析
2.语法:
        1.基本规则
                * 数据在名称/值对中:json数据是由键值对构成的
                        * 键用引号(单双)引起来,也可以不用引号
                        * 值的取值类型:
                                1.数字(整数或浮点数)         
                                2.字符串(在双引号中)
                                3.逻辑值(true或false)
                                4.数组(在方括号中){"person":[{}.{}]}
                                5.对象(花括号中){"address":{"province":"陕西"...}}
                                6.null
                * 数据由逗号分隔:多个键值对由逗号分隔
                * 花括号保存对象:使用{}定义json格式
                * 方括号保存数组:[]

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Json格式</title>
    <script>
        //1.定义基本格式
        var person = {"name":"张三",age:23,'gender':true};
        alert(person)
        //2.嵌套格式 {}-->[]
        var persons = {
            "persons":[
                {"name":"张三",age:23,'gender':true},
                {"name":"张",age:24,'gender':true},
                {"name":"张1",age:25,'gender':false}
            ]
        };
        alert(persons)
        //2.嵌套格式 []-->{}
        var ps = [
            {"name":"张三",age:23,'gender':true},
            {"name":"张",age:24,'gender':true},
            {"name":"张1",age:25,'gender':false}
        ];
    </script>
</head>
<body>

</body>
</html>

        2.获取数据
                1.json对象.键名
                2.json对象["键名"]
                3.数组对象[索引]

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Json格式</title>
    <script>
        //1.定义基本格式
        var person = {"name":"张三",age:23,'gender':true};
        //alert(person)

        //获取name的值
        var name = person["name"];
        // var name = person.name;
        alert(name)

        //2.嵌套格式 {}-->[]
        var persons = {
            "persons":[
                {"name":"张三",age:23,'gender':true},
                {"name":"张",age:24,'gender':true},
                {"name":"张1",age:25,'gender':false}
            ]
        };
        //alert(persons)

        //获取name的值
        var name1 = persons.persons[2].name;
        alert(name1)


        //2.嵌套格式 []-->{}
        var ps = [
            {"name":"张三",age:23,'gender':true},
            {"name":"张",age:24,'gender':true},
            {"name":"张1",age:25,'gender':false}
        ];
        //获取数据
        var name2 = ps[0].name;
        alert(name2)
    </script>
</head>
<body>

</body>
</html>

json遍历

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Json格式</title>
    <script>
        //json遍历
        //1.定义基本格式
        var person = {"name":"张三",age:23,'gender':true};

        //2.嵌套格式 []-->{}
        var ps = [
            {"name":"张三",age:23,'gender':true},
            {"name":"张",age:24,'gender':true},
            {"name":"张1",age:25,'gender':false}
        ];
        //获取person对象中的所有键和值
        //for in循环
        for(var key in person){
            //这种方式获取不行,因为相当于 persoon."name"
            //alert(key+":"+person.key) 错误
            alert(key+":"+person[key])
        }

        //获取ps中的所有值
        for(var i=0;i<ps.length;i++){
            var p = ps[i];
            for(var key in p){
                alert(key+":"+p[key])
            }
        }
    </script>
</head>
<body>

</body>
</html>

3.JSON数据和Java对象的相互转换
        * JSON解析器:常见的解析器:Jsonlib,Gson,fastjson,jackson
        1.JSON转为对象
                1.1.导入jackson的相关jar包
                        2.创建jackson核心对象 ObjectMapper
                        3.调用ObjectMapper的相关方法进行转换
                                * readValue(json字符串数据,Class)
        2.Java对象转换为JSON
                1.使用步骤:
                        1.导入jackson的相关jar包
                        2.创建jackson核心对象 ObjectMapper
                        3.调用ObjectMapper的相关方法进行转换

* 转换方法:
     writeValue(参数1,obj):
         * 参数1:
                File:将obj对象转换为JSON字符串,并保存到指定的文件中
                Writer:将obj对象转换为JSON字符串,并将json数据填充到字符输出流中
                OutputStream:将obj对象转换为JSON字符串,并将json数据填充到字节输出流中
     writeValueAsString(obj):将对象转为json字符串

*注解:
  1.@JsonIgnore:排除属性(在类中给属性加上这个注解,调用时这个属性不输出)
 2.@JsonFormat:属性值的格式化(在类中给属性机上这个注解,例如日期平时是转换为字符串
        加上@JsonFormat(yyyy-mm-dd)输出时便会按照这个格式输出)

 * 复杂java对象转换
        1.List
        2.Map

 

package ln.webtest.day01.domain;

import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.annotation.JsonIgnore;

import java.util.Date;

public class Person {
    private String name;
    private int age;
    private String gender;
    //@JsonIgnore
    @JsonFormat(pattern = "yyyy-MM-dd")
    private Date birthday;

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", gender='" + gender + '\'' +
                ", birthday=" + birthday +
                '}';
    }

    public Date getBirthday() {
        return birthday;
    }

    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }


    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getGender() {
        return gender;
    }

    public void setGender(String gender) {
        this.gender = gender;
    }

    public Person(String name, int age, String gender) {
        this.name = name;
        this.age = age;
        this.gender = gender;
    }

    public Person() {
    }
}
package ln.webtest.day01.test;

import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import ln.webtest.day01.domain.Person;
import org.junit.Test;

import java.io.File;
import java.io.IOException;
import java.util.*;

public class JacksonTest {
    //Java对象转为JSON字符串
    @Test
    public void test1() throws IOException {
        //创建Person对象
        Person p = new Person();
        p.setName("张三");
        p.setAge(23);
        p.setGender("男");

        //2.创建Jackson的核心对象 ObjectMapper
        ObjectMapper mapper = new ObjectMapper();
        //3.转换
        /*
            转换方法:
                writeValue(参数1,obj):
                    参数1:
                        File:将obj对象转换为JSON字符串,并保存到指定的文件中
                        Writer:将obj对象转换为JSON字符串,并将json数据填充到字符输出流中
                        OutputStream:将obj对象转换为JSON字符串,并将json数据填充到字节输出流中
                writeValueAsString(obj):将对象转为json字符串
        */
        String json = mapper.writeValueAsString(p);
        System.out.println(json); //{"name":"张三","age":23,"gender":"男"}

        //writeValue,将数据写到d://a.txt文件中
        mapper.writeValue(new File("d://a.txt"), p);

    }
    @Test
    public void test02() throws JsonProcessingException {
        /*
            注解:
                1.@JsonIgnore:排除属性(在类中给属性加上这个注解,调用时这个属性不输出)
                2.@JsonFormat:属性值的格式化(在类中给属性机上这个注解,例如日期平时是转换为字符串,加上@JsonFormat(yyyy-mm-dd)
                                          输出时便会按照这个格式输出)
        */
        //创建Person对象
        Person p = new Person();
        p.setName("张三");
        p.setAge(23);
        p.setGender("男");
        p.setBirthday(new Date());

        //2.创建Jackson的核心对象 ObjectMapper
        ObjectMapper mapper = new ObjectMapper();
        //3.转换
        String json = mapper.writeValueAsString(p);
        System.out.println(json);
    }
    @Test
    public void test03() throws JsonProcessingException {
        Person p = new Person();
        p.setName("张三");
        p.setAge(23);
        p.setGender("男");
        p.setBirthday(new Date());

        Person p1 = new Person();
        p1.setName("张1");
        p1.setAge(25);
        p1.setGender("女");
        p1.setBirthday(new Date());
        //创建List集合
        List<Person> ps = new ArrayList<>();
        ps.add(p);
        ps.add(p1);
        //2.转换
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(ps);
        System.out.println(json); //数组里放了两个Person对象
    }
    @Test
    public void test04() throws JsonProcessingException {
        //创建Map集合
        Map<String,Object> map = new HashMap<>();
        map.put("name", "张三");
        map.put("age", 23);
        map.put("gender", "男");

        //2.转换
        ObjectMapper mapper = new ObjectMapper();
        String json = mapper.writeValueAsString(map);
        System.out.println(json);
    }

    //JSON字符串转为Java对象
    @Test
    public void test05() throws IOException {
        //1.初始化JSON字符串
        String json = "{\"name\":\"张三\",\"age\":23,\"gender\":\"男\"}";
        //2.创建ObjectMapper对象
        ObjectMapper mapper = new ObjectMapper();
        //3.转换为Java对象 Person对象
        Person person = mapper.readValue(json, Person.class);
        System.out.println(person);
    }
}

案例:
* 校验用户名是否存在
        1.服务器响应的数据,在客户端使用时,要想当做json数据格式使用
                1.$.get(type):将最后一个参数type指定为json
                2.在服务器端设置MIME类型
                        response.setContentType("application/json";charset=utf-8");

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>注册页面</title>
    <script src="js/jquery.min.js"></script>
    <script>
        //在页面加载完成后
        $(function (){
            //给username绑定blur事件 (blur事件是失焦事件)
            $("#username").blur(function (){
                //获取username文本输入框的值
                var username = $(this).val();
                //发送ajax请求
                //期望服务器响应的数据格式:{"userExist":true,"msg":"此用户名太受欢迎,请更换一个"}
                //                      {"userExist":false,"msg":"用户名可用"}
                $.get("finUserServlet",{username:username},function(data){
                    //判断userExist键的值是否是true
                    var span = $("s_username");
                    if(data[userExist]){
                        //用户名存在
                        span.css("color","red");
                        span.html(data[msg]);
                    }else{
                        //用户名不存在
                        span.css("color","green");
                        span.html(data[msg]);
                    }
                },"json");
            });
        });
    </script>
</head>
<body>
<form>
    <input type="text" id="username" name="username" placeholder="请输入用户名" >
    <span id="s_username"></span><br>
    <input type="password" name="password" placeholder="请输入密码"><br>
    <input type="submit" value="注册"><br>

</form>
</body>
</html>
package ln.webtest.day01.Servlet;

import com.fasterxml.jackson.databind.ObjectMapper;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

@WebServlet("/findUserServlet")
public class FindUserServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.获取用户名
        String username = request.getParameter("username");
        //2.调用service层判断用户名是否存在
        //期望服务器响应的数据格式:{"userExist":true,"msg":"此用户名太受欢迎,请更换一个"}
        //                      {"userExist":false,"msg":"用户名可用"}
        //response.setContentType("text/html;charset=utf-8");
        response.setContentType("application/json;charset=utf-8");
        Map<String,Object> map = new HashMap<>();
        if("tom".equals(username)){
            //存在
            map.put("userExist",true);
            map.put("msg","此用户名太受欢迎,请更换一个");
        }else{
            //不存在
            map.put("userExist",false);
            map.put("msg","用户名可用");
        }
        //将map转为json,并且传递给客户端
        //将map转为json
        ObjectMapper mapper = new ObjectMapper();
        //传递客户端
        mapper.writeValue(response.getWriter(),map);
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值