使用json格式与服务器交互,使用json格式与服务器交互文件

本文目录一览:

处理和响应JSON数据

处理和响应JSON数据

使用 HTTP POST 方法传到网站服务器的数据格式可以有很多种,比如「获取POST方法传送的数据」课程中讲到的name=Loenpassword=loveyou这种用过符号分割的key-value键值对格式。我们也可以用JSON格式、XML格式。相比XML的重量、规范繁琐,JSON显得非常小巧和易用。

如果POST的数据是JSON格式,request.json会自动将json数据转换成Python类型(字典或者列表)。

编写server.py:

from flask import Flask, request

app = Flask(“myapp”)

@app.route(‘/add’, methods=[‘POST’])

def add():

    print(request.headers)

    print(type(request.json))

    print(request.json)

    result = request.json[‘n1’] + request.json[‘n2’]

    return str(result)

if __name__ == ‘__main__’:

    app.run(host=’127.0.0.1′, port=5000, debug=True)

编写client.py模拟浏览器请求:

import requests

json_data = {‘n1’: 5, ‘n2’: 3}

r = requests.post(“”, json=json_data)

print(r.text)

运行server.py,然后运行client.py,client.py 会在终端输出:

注意,请求头中Content-Type的值是application/json。

响应JSON

响应JSON时,除了要把响应体改成JSON格式,响应头的Content-Type也要设置为application/json。

编写server.py:

from flask import Flask, request, Response

import json

app = Flask(“myapp”)

@app.route(‘/add’, methods=[‘POST’])

def add():

    result = {‘sum’: request.json[‘n1’] + request.json[‘n2’]}

    return Response(json.dumps(result),  mimetype=’application/json’)

if __name__ == ‘__main__’:

    app.run(host=’127.0.0.1′, port=5000, debug=True)

修改后运行。

编写client.py:

import requests

json_data = {‘n1’: 5, ‘n2’: 3}

r = requests.post(“”, json=json_data)

print(r.headers)

print(r.text)

运行client.py,将显示:

client终端返回的第一段内容是服务器的响应头,第二段内容是响应体,也就是服务器返回的JSON格式数据。

另外,如果需要服务器的HTTP响应头具有更好的可定制性,比如自定义Server,可以如下修改add()函数:

@app.route(‘/add’, methods=[‘POST’])

def add():

    result = {‘sum’: request.json[‘n1’] + request.json[‘n2’]}

    resp = Response(json.dumps(result),  mimetype=’application/json’)

    resp.headers.add(‘Server’, ‘python flask’)

    return resp

client.py运行后会输出:

{‘Content-Type’: ‘application/json’, ‘Content-Length’: ’10’, ‘Server’: ‘python flask’, ‘Date’: ‘Wed, 11

Sep 2019 09:09:18 GMT’}

{“sum”: 8}

响应JSON

使用 jsonify 工具函数。

from flask import Flask, request, jsonify

app = Flask(“myapp”)

@app.route(‘/add’, methods=[‘POST’])

def add():

    result = {‘sum’: request.json[‘n1’] + request.json[‘n2’]}

    return jsonify(result)

if __name__ == ‘__main__’:

    app.run(host=’127.0.0.1′, port=5000, debug=True)

运行结果:

在 java web开发中怎么使用json?

一、JSON建构有两种结构:

json简单说就是javascript中的对象和数组,所以这两种结构就是对象和数组2种结构,通过这两种结构可以表示各种复杂的结构

1、对象:对象在js中表示为“{}”括起来的内容,数据结构为 {key:value,key:value,…}的键值对的结构,在面向对象的语言中,key为对象的属性,value为对应的属性值,所以很容易理解,取值方法为 对象.key 获取属性值,这个属性值的类型可以是 数字、字符串、数组、对象几种。在Java中就是一种Map结构。

2、数组:数组在js中是中括号“[]”扩起来的内容,数据结构为 [“java”,”javascript”,”vb”,…],取值方式和所有语言中一样,使用索引获取,字段值的类型可以是 数字、字符串、数组、对象几种。在Java中是一种list结构。

经过对象、数组2种结构就可以组合成复杂的数据结构了。

二、Json in Javascript

使用Json语法创建对象

var people = {“name”:”jack”,”sex”:”mail”};

可以通过这种语法创建json对象,用“{}”括起来,用“,”隔开key:value

使用Json语法创建数组

var arr =[value1,value2…];

一个包含多个people的数组 peoples = [{“name”:”jack”,”sex”:”mail”},

“name”:”lily”,”sex”:”femail”};

Json数组可以通过这种语法创建,用”[]”括起来,数组元素之间用“,”分隔开,下面是这种语法的示意图:

在使用Json格式字符串与服务器交互时候,可以利用Json扩展的方法将字符串转换成一个JavaScript对象,或者将一个对象转换成Json格式字符串。不过先要登录下载Json2.js文件。引入该包后,js对象直接用toJSONString()装换为字符串格式,字符串可以用parseJSON()转换成js对象。

访问数据

只需用点号表示法来表示数组元素。所以,要想访问 上面peoples列表的第一个条目的名字,只需在 JavaScript 中使用下面这样的代码:

peoples[0].name

利用这样的语法,可以处理任何 JSON 格式的数据,而不需要使用任何额外的 JavaScript 工具包或 API。

修改数据

正如可以用点号和方括号访问数据,也可以按照同样的方式轻松地修改数据:

peoples[0].name = “Rachmaninov”;

在将字符串转换为 JavaScript 对象之后,就可以像这样修改变量中的数据。

如何使用JSON格式 POST数据到服务器

1. JSON的数据格式a) 按照最简单的形式,可以用下面这样的 JSON 表示名称/值对:{ “firstName”: “Brett” }b) 可以创建包含多个名称/值对的记录,比如:{ “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” }c) 可以创建值的数组{ “people”: [ { “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” }, { “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” }]}d) 当然,可以使用相同的语法表示多个值(每个值包含多个记录):{ “programmers”: [ { “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” }, { “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” } ],”authors”: [ { “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science fiction” }, { “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” }],”musicians”: [ { “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar” }]}注意,在不同的主条目(programmers、authors 和 musicians)之间,记录中实际的名称/值对可以不一样。JSON 是完全动态的,允许在 JSON 结构的中间改变表示数据的方式。

2. 在 JavaScript 中使用 JSONJSON 是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON 数据不需要任何特殊的 API 或工具包。

2.1 将 JSON 数据赋值给变量例如,可以创建一个新的 JavaScript 变量,然后将 JSON 格式的数据字符串直接赋值给它:var people = { “programmers”: [ { “firstName”: “Brett”, “lastName”:”McLaughlin”, “email”: “brett@newInstance.com” }, { “firstName”: “Jason”, “lastName”:”Hunter”, “email”: “jason@servlets.com” } ], “authors”: [ { “firstName”: “Isaac”, “lastName”: “Asimov”, “genre”: “science fiction” }, { “firstName”: “Tad”, “lastName”: “Williams”, “genre”: “fantasy” } ], “musicians”: [ { “firstName”: “Eric”, “lastName”: “Clapton”, “instrument”: “guitar” } ] }

2.2 访问数据将这个数组放进 JavaScript 变量之后,就可以很轻松地访问它。实际上,只需用点号表示法来表示数组元素。所以,要想访问 programmers 列表的第一个条目的姓氏,只需在JavaScript 中使用下面这样的代码:people.programmers[0].lastName;注意,数组索引是从零开始的。

2.3 修改 JSON 数据正如访问数据,可以按照同样的方式修改数据:people.musicians[1].lastName = “Rachmaninov”;

2.4 转换回字符串a) 在 JavaScript 中这种转换也很简单:String newJSONtext = people.toJSONString();b) 可以将任何 JavaScript 对象转换为 JSON 文本。并非只能处理原来用 JSON 字符串赋值的变量。为了对名为 myObject 的对象进行转换,只需执行相同形式的命令:String myObjectInJSON = myObject.toJSONString();说明:将转换回的字符串作为Ajax调用的字符串,完成异步传输。小结:如果要处理大量 JavaScript 对象,那么 JSON 几乎肯定是一个好选择,这样就可以轻松地将数据转换为可以在请求中发送给服务器端程序的格式。

3. 服务器端的 JSON3.1 将 JSON 发给服务器a)

通过 GET 以名称/值对发送 JSON在 JSON 数据中会有空格和各种字符,Web 浏览器往往要尝试对其继续编译。要确保这些字符不会在服务器上(或者在将数据发送给服务器的过程中)引起混乱,需要在JavaScript的escape()函数中做如下添加:var url = “organizePeople.php?people=” + escape(people.toJSONString());request.open(“GET”, url, true);request.onreadystatechange = updatePage;request.send(null);b) 利用 POST 请求发送 JSON 数据当决定使用 POST 请求将 JSON 数据发送给服务器时,并不需要对代码进行大量更改,如下所示:var url = “organizePeople.php?timeStamp=” + new Date().getTime();request.open(“POST”, url, true);request.onreadystatechange = updatePage;request.setRequestHeader(“Content-Type”, “application/x-www-form-urlencoded”);request.send(people.toJSONString());注意:赋值时格式必须是var msg=eval(‘(‘ + req.responseText + ‘)’);

3.2 在服务器上解释 JSONa) 处理 JSON 的两步骤。 针对编写服务器端程序所用的语言,找到相应的 JSON 解析器/工具箱/帮助器 API。 使用 JSON 解析器/工具箱/帮助器 API 取得来自客户机的请求数据并将数据转变成脚本能理解的东西。 b) 寻找 JSON 解析器寻找 JSON 解析器或工具箱最好的资源是 JSON 站点。如果使用的是 Java servlet,json.org 上的 org.json 包就是个不错的选择。在这种情况下,可以从 JSON Web 站点下载 json.zip 并将其中包含的源文件添加到项目构建目录。编译完这些文件后,一切就就绪了。对于所支持的其他语言,同样可以使用相同的步骤;使用何种语言取决于您对该语言的精通程度,最好使用您所熟悉的语言。c) 使用 JSON 解析器一旦获得了程序可用的资源,剩下的事就是找到合适的方法进行调用。如果在 servlet 中使用的是 org.json 包,则会使用如下代码:public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { StringBuffer jb = new StringBuffer(); String line = null; try { BufferedReader reader = request.getReader(); while ((line = reader.readLine()) != null) jb.append(line); } catch (Exception e) { //report an error } try { JSONObject jsonObject = new JSONObject(jb.toString()); } catch (ParseException e) { // crash and burn throw new IOException(“Error parsing JSON request string”); } // Work with the data using methods like… // int someInt = jsonObject.getInt(“intParamName”); // String someString = jsonObject.getString(“stringParamName”); // JSONObject nestedObj = jsonObject.getJSONObject(“nestedObjName”); // JSONArray arr = jsonObject.getJSONArray(“arrayParamName”); // etc…}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/188775.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-28 13:33
下一篇 2024-11-28 13:33

相关推荐

  • vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常问题的解决

    本文旨在解决vue下载无后缀名的文件被加上后缀.txt,有后缀名的文件下载正常的问题,提供完整的代码示例供参考。 一、分析问题 首先,需了解vue中下载文件的情况。一般情况下,我们…

    编程 2025-04-29
  • 如何在Java中拼接OBJ格式的文件并生成完整的图像

    OBJ格式是一种用于表示3D对象的标准格式,通常由一组顶点、面和纹理映射坐标组成。在本文中,我们将讨论如何将多个OBJ文件拼接在一起,生成一个完整的3D模型。 一、读取OBJ文件 …

    编程 2025-04-29
  • 为什么用cmd运行Java时需要在文件内打开cmd为中心

    在Java开发中,我们经常会使用cmd在命令行窗口运行程序。然而,有时候我们会发现,在运行Java程序时,需要在文件内打开cmd为中心,这让很多开发者感到疑惑,那么,为什么会出现这…

    编程 2025-04-29
  • Python中读入csv文件数据的方法用法介绍

    csv是一种常见的数据格式,通常用于存储小型数据集。Python作为一种广泛流行的编程语言,内置了许多操作csv文件的库。本文将从多个方面详细介绍Python读入csv文件的方法。…

    编程 2025-04-29
  • Python程序文件的拓展

    Python是一门功能丰富、易于学习、可读性高的编程语言。Python程序文件通常以.py为文件拓展名,被广泛应用于各种领域,包括Web开发、机器学习、科学计算等。为了更好地发挥P…

    编程 2025-04-29
  • Python将矩阵存为CSV文件

    CSV文件是一种通用的文件格式,在统计学和计算机科学中非常常见,一些数据分析工具如Microsoft Excel,Google Sheets等都支持读取CSV文件。Python内置…

    编程 2025-04-29
  • Python zipfile解压文件乱码处理

    本文主要介绍如何在Python中使用zipfile进行文件解压的处理,同时详细讨论在解压文件时可能出现的乱码问题的各种解决办法。 一、zipfile解压文件乱码问题的根本原因 在P…

    编程 2025-04-29
  • Python如何导入py文件

    Python是一种开源的高级编程语言,因其易学易用和强大的生态系统而备受青睐。Python的import语句可以帮助用户将一个模块中的代码导入到另一个模块中,从而实现代码的重用。本…

    编程 2025-04-29
  • Python合并多个相同表头文件

    对于需要合并多个相同表头文件的情况,我们可以使用Python来实现快速的合并。 一、读取CSV文件 使用Python中的csv库读取CSV文件。 import csv with o…

    编程 2025-04-29
  • 服务器安装Python的完整指南

    本文将为您提供服务器安装Python的完整指南。无论您是一位新手还是经验丰富的开发者,您都可以通过本文轻松地完成Python的安装过程。以下是本文的具体内容: 一、下载Python…

    编程 2025-04-29

发表回复

登录后才能评论