Ajax基于JSON的数据传输,前后端需要进行格式的转换

8 篇文章 0 订阅
2 篇文章 0 订阅

在Ajax请求中服务器端向浏览器端响应的数据大多是基于JSON格式的字符串,这样就需要在服务器端和浏览器端做如下工作:

1.在服务器端将Java对象转换成JSON格式的字符串

        在这里有多种方法,我今天给大家介绍其中使用比较多的一种:阿里巴巴的fastjson组件,它可以将java对象转换成json格式的字符串。注意:使用fastjson需要引入fastjson-1.2.2.jar

服务器端代码如下:(连接数据库查询出结果之后)

List<Student> studentList = new ArrayList<>();

while (rs.next()) {

    // 取出数据

    String name = rs.getString("name");

    int age = rs.getInt("age");

    String addr = rs.getString("addr");

    // 将以上数据封装成Student对象

    Student s = new Student(name, age, addr);

    // 将Student对象放到List集合

    studentList.add(s);

}

// 将List集合转换成json字符串

jsonStr = JSON.toJSONString(studentList);

//将转换之后的字符串响应给前端

//为了防止出现中文乱码需要添加下行代码

response.setContentType("text/html;charset=UTF-8");

//获取输出流

PrintWriter out = response.getWriter();

out.print(jsonStr);

2.在浏览器端将接收到的JSON格式的字符串转换成JSON对象

if(xhr.readyState == 4){

        if(xhr.status == 200){

                //接收JSON格式的字符串

                var jsonStr = xhr.responsetext

                //将JSON格式的字符串转换成JSON对象

                var jsonObj = JSON.parse(jsonStr);

        }

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
利用jquery的ajax方法可以进行前后端的交互。以下是一个使用JSON进行数据传输的示例: 前端代码: ```javascript // 定义要发送的数据 var data = { name: '张三', age: 20, gender: '男' }; // 将数据对象转为JSON字符串 var jsonData = JSON.stringify(data); $.ajax({ url: 'backend.php', // 后端接口地址 type: 'POST', // 请求方法为POST data: { jsonData: jsonData // 向后端传递JSON数据 }, dataType: 'json', // 预期接收的数据类型为JSON success: function(response) { // 请求成功后的处理逻辑 console.log('后端返回的结果为:', response); }, error: function(xhr, status, error) { // 请求失败后的处理逻辑 console.log('请求失败', error); } }); ``` 后端代码(使用PHP语言作为示例): ```php // 接收前端传递的JSON数据 $jsonData = $_POST['jsonData']; // 将JSON字符串转换为PHP对象 $data = json_decode($jsonData); // 在后端进行对传递的数据的处理 $name = $data->name; $age = $data->age; $gender = $data->gender; // 构造要返回给前端的JSON数据 $response = array( 'result' => 'success', 'message' => '数据接收成功', 'name' => $name, 'age' => $age, 'gender' => $gender ); // 将数据转为JSON字符串 $jsonResponse = json_encode($response); // 返回JSON响应 header('Content-type: application/json'); echo $jsonResponse; ``` 以上就是一个使用jquery的ajax方法进行前后端交互,并通过JSON传递数据的示例。前端通过ajax发送JSON数据到后端,后端接收后进行处理后再返回一个JSON响应给前端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值