JSON 数据解析的方法

article/2025/11/11 0:22:26

JSON 数据解析

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。 

JSON的规则很简单: 对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。具体细节参考http://www.json.org/json-zh.html

举个简单的例子:

js 代码

function showJSON() {var user = {"username": "andy","age": 20,"info": {"tel": "123456","cellphone": "98765"},"address": [{"city": "beijing","postcode": "222333"}, {"city": "newyork","postcode": "555666"}]}alert(user.username);alert(user.age);alert(user.info.cellphone);alert(user.address[0].city);alert(user.address[0].postcode);
}

这表示一个user对象,拥有username, age, info, address 等属性。
同样也可以用JSON来简单的修改数据,修改上面的例子,得到:

js 代码

function showJSON() {var user = {"username": "andy","age": 20,"info": {"tel": "123456","cellphone": "98765"},"address": [{"city": "beijing","postcode": "222333"}, {"city": "newyork","postcode": "555666"}]}alert(user.username);alert(user.age);alert(user.info.cellphone);alert(user.address[0].city);alert(user.address[0].postcode);user.username = "Tom";alert(user.username);
}

JSON提供了json.js包,下载http://www.json.org/json.js 后,将其引入然后就可以简单的使用​object.toJSONString()​转换成JSON数据。
 

js 代码

function showCar() {var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow");alert(carr.toJSONString());
}function Car(make, model, year, color) {this.make = make;this.model = model;this.year = year;this.color = color;
}

可以使用​eval​来转换JSON字符到Object

js 代码

function myEval() { var str = '{ "name": "Violet", "occupation": "character" }'; var obj = eval('(' + str + ')'); alert(obj.toJSONString()); 
}

或者使用​parseJSON()​方法

js 代码

function myEval() {var str = '{ "name": "Violet", "occupation": "character" }';var obj = str.parseJSON();alert(obj.toJSONString());
}

下面使用prototype写一个JSON的ajax例子。
先写一个servlet (我的是servlet.ajax.JSONTest1.java)就写一句话
java 代码

response.getWriter().print("{ \"name\": \"Violet\", \"occupation\": \"character\" }");

再在页面中写一个ajax的请求

js 代码

 

function sendRequest() {

    var url = "/MyWebApp/JSONTest1";

    var mailAjax = new Ajax.Request(

        url, {

        method: 'get',

        onComplete: jsonResponse

    });

}

function jsonResponse(originalRequest) {

    alert(originalRequest.responseText);

    var myobj = originalRequest.responseText.parseJSON();

    alert(myobj.name);

}

prototype-1.5.1.js中提供了JSON的方法,String.evalJSON(), 可以不使用json.js, 修改上面的方法

js 代码

function jsonResponse(originalRequest) {alert(originalRequest.responseText);var myobj = originalRequest.responseText.evalJSON(true);alert(myobj.name);
}

JSON还提供了java的jar包 http://www.json.org/java/index.html API也很简单,下面举个例子
在javascript中填加请求参数

js 代码

function sendRequest() {var carr = new Car("Dodge", "Coronet R/T", 1968, "yellow");var pars = "car=" + carr.toJSONString();var url = "/MyWebApp/JSONTest1";var mailAjax = new Ajax.Request(url, {method: 'get',parameters: pars,onComplete: jsonResponse});
}

使用JSON请求字符串就可以简单的生成JSONObject并进行解析,修改servlet添加JSON的处理(要使用json.jar)
java 代码

 

private void doService(HttpServletRequest request, HttpServletResponse response) throws IOException {

    String s3 = request.getParameter("car");

    try {

        JSONObject jsonObj = new JSONObject(s3);

        System.out.println(jsonObj.getString("model"));

        System.out.println(jsonObj.getInt("year"));

    } catch (JSONException e) {

        e.printStackTrace();

    }

    response.getWriter().print("{ \"name\": \"Violet\", \"occupation\": \"character\" }");

}

同样可以使用JSONObject生成JSON字符串,修改servlet

java 代码

private void doService(HttpServletRequest request, HttpServletResponse response) throws IOException {String s3 = request.getParameter("car");try {JSONObject jsonObj = new JSONObject(s3);System.out.println(jsonObj.getString("model"));System.out.println(jsonObj.getInt("year"));} catch (JSONException e) {e.printStackTrace();}JSONObject resultJSON = new JSONObject();try {resultJSON.append("name", "Violet").append("occupation", "developer").append("age", new Integer(22));System.out.println(resultJSON.toString());} catch (JSONException e) {e.printStackTrace();}response.getWriter().print(resultJSON.toString());
}

js 代码

 

function jsonResponse(originalRequest) {

    alert(originalRequest.responseText);

    var myobj = originalRequest.responseText.evalJSON(true);

    alert(myobj.name);

    alert(myobj.age);

}

下面在重点给大家介绍JS中json数据的处理:
1、 json数据结构(对象和数组)
json对象:​var obj = {"name":"xiao","age":12};
json数组:​​

var objArray = [{"name":"xiao","age":12},{"name":"xiao","age":12}];

2、 处理json数据,依赖文件有:jQuery.js
 

3、Note:数据传输过程中,json数据是以文本,即字符串格式形式存在;
JS语言操作的是JS对象;
所以json字符串与JS对象之间的转换是关键;
 

4、数据格式
Json字符串:var json_str = ‘{"name":"xiao","age":12}';
Josn对象:var obj = {"name":"xiao","age":12};
JS对象:Object {name: "xiao", age: 12}
 

5、类型转换
Json字符串——>JS对象,使用方法:

注明:json_str、obj代表的是在本文子标题4中的数据类型;

obj = JSON.parse(json_str);
obj = jQuery.parseJSON(json_str);
Note:传入畸形json字符串(例如:‘{name:"xiao",age:12}'),会抛出异常;
Json字符串格式,严格格式:‘{"name":"xiao","age":12}'
JS对象——>Json字符串:
json_str = JSON. stringify(obj);

NOTE:

1、eval()是JS原生函数,使用该形式:eval(‘('+‘{name:"xiao",age:12}'+')'),并不安全,无法保证类型转换为JS对象;

2、上面3中方法,都经过chrome浏览器测试,下面是测试结果截图;

Json字符串——>JS对象;

JS对象——>Json字符串:


http://chatgpt.dhexx.cn/article/vgbrxOM5.shtml

相关文章

手动JSON数据解析

1.将json格式的字符串{}转化为JAVA对象 //第一步:获取或创建Json数据String json "{\n" " \"id\":2,\"name\":\"小龙虾\",\n" " \"price\":12.3,\n" " …

【Python爬虫与数据分析】爬虫Json数据解析

目录 一、Json文件数据解析 二、Json数据包解析获取图片资源 三、Json数据包解析获取视频资源 一、Json文件数据解析 json字符串:通常类似python数据类型中的列表和字典的结合,也可能是单独的列表或者字典格式,通常可以通过json模块的函数…

Json格式数据解析

一、简介 XML这种数据格式。XML的特点是功能全面,但标签繁琐,格式复杂。在Web上使用XML现在越来越少,取而代之的是JSON这种数据结构。 JSON是JavaScript Object Notation的缩写,它去除了所有JavaScript执行代码,只保…

JSON解析

#粤嵌星计划,粤嵌我来了# #粤嵌星计划,粤嵌我来了# 1、什么是JSON (1)JSON(Java Script Object Notation)是一种轻量级的数据交换语言,以文本字符串为基础,且易于让人阅读。&#x…

内网穿透原理解析

在互联网信息时代的今天,经常会听到外网连接。而与外网所相对应的,是一种内部网络,很多的家庭或者公司利用内部网络来进行多台电脑之间的资源共享,其中所用到的技术就是内网穿透技术,但却有很多的人对这种技术并不了解…

内网穿透原理概要

详细原理的解析 https://blog.csdn.net/xinpz/article/details/82732217 运行原理流程图 什么是内网穿透? 内网穿透是我们在进行网络连接时的一种术语,也叫做NAT穿透,即在计算机是局域网内的时候,外网与内网的计算机的节点进行连接时所需…

内网穿透内容讲解

内网穿透又叫端口映射,用一句最简单的话来讲就是:将你的计算机所连接的私有网络映射到公网上,别人通过你给的域名或ip即可访问你本地的服务。具体的原理可参照百度百科 这么做可以实现各大厂商的云服务器(阿里云,腾讯云…

内网穿透你真的了解吗?

前言 内网穿透作为程序员常用的调试手段之一,我们可以通过在个人电脑上运行花生壳或者 frp 等方式,让他人访问我们本地启动的服务,而且这种访问可以不受局域网的限制,当我们使用ngrok,frp等开源框架时,你是否有好奇过…

Ngrok内网穿透

Ngrok一款内网穿透工具,它可以将本地部署的Web应用能够让公网环境直接访问到。ngrok是一个反向代理,通过在公共端点和本地运行的Web服务器之间建立一个安全的通道,实现内网主机的服务可以暴露给外网。所以它提供了一个能够在公网安全访问内网…

大白话告诉你内网穿透原理和验证

内网穿透到底干啥的这里不做详述,这篇文章主要是讲这玩意怎么做的 分析 网上有很多原理图,但是说实话鄙人天资愚钝没咋看懂,在网上疯狂百度和个人的验证之后,得出如下简图 其实很简单 想让我们内网的服务能被外网访问到&#x…

frp内网穿透原理及配置应用

1 Frp介绍 frp 是一个专注于内网穿透的高性能的反向代理应用,支持 TCP、UDP、HTTP、HTTPS 等多种协议。可以将内网服务以安全、便捷的方式通过具有公网 IP 节点的中转暴露到公网。 frp 项目官网 https://github.com/fatedier/frp 中文文档 https://github.com/fat…

内网穿透原理,以及用花生壳实现内网穿透

在做自学项目部署nginx的时候,nginx部署在阿里云服务器上,项目在本地,阿里云的nginx无法访问到本地的ip,所以需要做一下内网穿透。记录一下 什么是内网穿透? 内网和外网的概念: 内网:即所说的局…

内网穿透原理和实现

什么是内网穿透 作者:匿名用户 链接:https://www.zhihu.com/question/63098230/answer/1929852198 希望对你们更易懂要知道这个的意思,需要先来点前菜 1、地球上的电脑设备等要实现通信,都需要有个IP地址才可以实现。 2、IP地址…

内网穿透原理和实现思路介绍

内网穿透技术,简单理解就是将内网的服务映射到公网中,这样可以随时随地访问。 那什么是内网?什么是公网?先从这个基本概念来简单介绍吧 1. 公网、内网和外网 首先声明,公网、内网和外网这几个概念,不是专…

内网穿透工具frp原理和使用教程

内网穿透(Port Forwarding)是将公网上的IP地址映射到内部网络中的一台计算机的某个端口上,以便外部网络可以访问该计算机中运行的应用程序。内网穿透技术可以通过一些开源工具来实现,其中比较常用的是frp。在本文中,我…

内网穿透原理

前言 内网穿透一般在家庭用户下NAS设备在经常折腾,实际上企业云服务就是典型的内网穿透,只不过方式原理有点不同,家庭网络因为宽带的上传限制和没有公网IP,难度大于企业宽带。实际上内网穿透就是反向代理,域名解析&am…

内网穿透的实现和原理解析

需求场景: 基于微信平台开发服务号,本地移动端测试时,需要在微信平台注册测试号,然后填写接口配置信息,此信息需要你有自己的服务器资源,填写的URL需要正确响应微信发送的Token验证。如何能让外网访问到本地服务器呢&…

MacBook M1 Idea集成SVN

1.检查是否安装SVN svn —version2.检查是否安装了brew brew -v3.安装 brew /bin/zsh -c "$(curl -fsSL https://gitee.com/cunkai/HomebrewCN/raw/master/Homebrew.sh)” speed4.记住安装路径 5.配置国内镜像源HOMEBREW BOTTLE 6.svn安装前需要执行 按照/usr/local路径…

IntelliJ IDEA上svn分支管理和使用

IntelliJ IDEA上svn分支管理和使用 从Subversion下载trunk下的代码 选择项目创建分支 右键 Subversion --> branch or Tag … 选择Repository Location:需要创建的项目 选择Any Location 分支的位置和名字 详细查看截图 切换到分支 选择项目右键Subversion --> Update …

vscode / idea 使用SVN及查看历史记录

一、vscode使用 SVN 1、在vscode插件中心搜索svn 进行安装(我这里已经安装完毕了) 注意:插件安装成功,需要重新启动软件。 安装成功后会出现如下的图标: 2、桌面右键使用SVN Checkout… 来检出远程库的代码&#xf…