前后端交互常见的几种数据传输格式

目录

[1. get请求 query string](#1. get请求 query string)

2.form表单+get请求

3..form表单+post请求

4..json格式

5.总结


1. get请求 query string

前端通过get请求携带 query string(键值对) ,后端通过req.getParameter(key)方法获取数据。如果key不存在,获取到的就是null。querystring 会被 Tomcat 处理成形如Map这样的结构,就可以通过key获取value了。这种是直接在地址栏里输入querystring: ?username=lisi&password=123。

java 复制代码
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        resp.setContentType("text/html;charset=utf8");
        resp.getWriter().write("username="+username+" password="+password);
    }

2.form表单+get请求

和上面差不多,一个是以get方式在地址栏手写querystring,这个是通过form表单构造get请求,同样也是在传querystring。可以看到get请求会将数据显示在地址栏上。

后端

java 复制代码
@WebServlet("/test")
public class test extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        resp.setContentType("text/html;charset=utf8");
        resp.getWriter().write("我是响应数据");
    }
}

前端

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="test" method="get">
        <input type="text" name="username">
        <input type="text" name="password">
        <input type="submit">
    </form>
</body>
</html>

后端通过前端name属性所对应的字符串获取到输入的数据。

通过fiddler抓包可以看到get请求请求的数据被拼接到了URL后面,后端我通过resp.getWriter().writer()进行响应,响应数据是在body中被传回来的。


3..form表单+post请

请求在body中被传过去,不会显示在地址栏上。同样使用getParameter方法可以获取到value。通过前端name属性所对应的字符串获取到输入的数据。

后端

java 复制代码
@WebServlet("/test")
public class test extends HttpServlet {
    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        String username = req.getParameter("username");
        String password = req.getParameter("password");
        resp.setContentType("text/html;charset=utf8");
        resp.getWriter().write("我是响应数据");
    }
}

前端

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <form action="test" method="post">
        <input type="text" name="username">
        <input type="text" name="password">
        <input type="submit">
    </form>
</body>
</html>

通过抓包可以看到,post请求的数据不会被拼接到URL后面,而是通过存在在body中传过去的。

响应数据还是在body中传回来的。这就是人们所说的post请求安全,get请求不安全。


4..json格式

json是一种键值对结构的数据格式。通过请求的body中传过去。

格式:

{

username: lisi,

password: 123

}

或嵌套:

{

{

username: zhangsan,

password: 666

}

{

username: lihiai,

password: 456

}

}

使用它我们需要引入jackson这样的第三方库。在maven中央仓库中搜索jackson。

或直接在你的项目的pom.xml中加入下面这段代码,再刷新即可:

java 复制代码
<!-- https://mvnrepository.com/artifact/com.fasterxml.jackson.core/jackson-databind -->
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.14.2</version>
        </dependency>
java 复制代码
public class test extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        ObjectMapper mapper = new ObjectMapper();
        
        /*第一种处理方式*/
        // 是把请求中的数据转成对象
        Users users1 = mapper.readValue(req.getInputStream(), Users.class);
        // 1.通过第一个参数先从body中以字节为单位读取出json格式的字符串
        // 2.通过第二个参数 创建Users实例
        // 3.解析json格式的字符串 并转换成map键值对结构
        // 4.对map的key进行遍历与实例的属性名进行匹配 匹配成功后就会把map的value赋值给该实例的属性。
        // 5.返回该实例
        
        /*第二种处理方式*/
        // 是返回该对象的json格式的字符串
        // 这个新构造的users是空的 实际中是获取到已有的
        Users users = new Users();
        String respJson = mapper.writeValueAsString(users);
        resp.setContentType("application/json;charset=utf8");
        resp.getWriter().write(respJson);

    }
}

5.总结

前端通过form表单将请求提交到tomcat服务器,Tomcat接收到请求之后,解析该请求,会把这个请求的方法,URL,版本号,各种header,body啥的都解析出来,构造成req对象(这里面就存着该请求的相关数据,通过它里面的已有的各种方法可以获取到)和resp象。 Tomcat通过请求中的url和请求方法选择并调用我们自己写的继承自HttpServlet的类的doPost方法或doGet方法等等,我们需要重写方法。最后通过resp对象包装响应数据数据返回给Tomcat,tomcat发送给浏览器。

相关推荐
都在酒里1 小时前
Linux字符设备驱动开发(二):实现数据交互——内核与用户空间的内存拷贝
linux·驱动开发·交互
UXbot2 小时前
初创公司如何选择合适的UI工具支撑快速迭代产品?
人工智能·低代码·ios·交互·原型模式
招风的黑耳2 小时前
Axure动态柱状图设计指南:从静态到交互的完整实现
交互·axure·柱状图
招风的黑耳2 小时前
Axure动态折线图设计指南:从静态到交互的完整实现
交互·axure·photoshop
UXbot2 小时前
轻量级原型工具如何支持Web应用的完整设计到开发链路
android·前端·人工智能·ios·交互·ui设计
Swift社区3 小时前
鸿蒙 PC 与 AI Runtime:下一代桌面交互
人工智能·交互·harmonyos
艺杯羹3 小时前
Vibe Coding实战:从零构建网页3D交互角色
3d·ai·交互·ai编程·ai agent·vibe coding
Lenyiin2 天前
第5篇_Python文件操作与异常处理:程序与外界交互的桥梁
python·oracle·交互
ZC跨境爬虫2 天前
跟着 MDN 学CSS day_17:(深入理解溢出机制与容器控制艺术)
前端·javascript·css·ui·交互
AZaLEan__2 天前
纯 HTML+CSS 实现 换一换 交互
css·html·交互