SpringBoot——如何读写使用JSON文件保存的数据

1. 将数据写入JSON文件

要将数据写入JSON文件,可以使用Spring Boot中提供的Jackson库。Jackson库是处理JSON的Java库,可以轻松地将对象转换为JSON字符串,并将其写入文件。

首先,确保你的Spring Boot项目中已经引入了Jackson库的依赖。在pom.xml文件中添加以下依赖:

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
</dependency>

接下来,创建一个包含数据的Java对象。这个对象将被转换为JSON格式并写入文件。假设你有一个Person类,表示一个人的信息:

public class Person {
    private String name;
    private int age;
    
    // 构造函数、getter和setter等方法
    
    // 省略其他代码
}

现在,可以使用ObjectMapper类将对象转换为JSON字符串,并将其写入文件。

示例代码:

import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.File;
import java.io.IOException;

public class JsonFileWriter {
    public void writeJsonToFile(Person person) {
        ObjectMapper objectMapper = new ObjectMapper();
        
        try {
            objectMapper.writeValue(new File("person.json"), person);
            System.out.println("JSON文件写入成功!");
        } catch (IOException e) {
            System.out.println("JSON文件写入失败:" + e.getMessage());
        }
    }
}

在上面的示例中,ObjectMapper类的writeValue()方法接受两个参数:文件对象和要写入文件的对象。在这个例子中,我们将person对象写入名为person.json的文件中。

调用writeJsonToFile()方法将触发写入操作:

Person person = new Person();
person.setName("Alice");
person.setAge(25);

JsonFileWriter jsonFileWriter = new JsonFileWriter();
jsonFileWriter.writeJsonToFile(person);

执行上述代码后,会在项目根目录下生成一个名为person.json的文件,内容如下:

{"name":"Alice","age":25}

这就是将数据写入JSON文件的简单示例。可以根据自己的需要进行扩展和调整。

2. 从JSON文件读取数据

2.1 读取单个对象

可以使用ObjectMapper类来读取JSON文件并将其转换为Java对象。

示例代码:

import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.File;
import java.io.IOException;

public class JsonFileReader {
    public Person readJsonFromFile() {
        ObjectMapper objectMapper = new ObjectMapper();
        
        try {
            Person person = objectMapper.readValue(new File("person.json"), Person.class);
            System.out.println("JSON文件读取成功!");
            return person;
        } catch (IOException e) {
            System.out.println("JSON文件读取失败:" + e.getMessage());
            return null;
        }
    }
}

在上述示例中,ObjectMapper类的readValue()方法接受两个参数:文件对象和要将JSON数据转换为的对象类型。在这个例子中,我们将JSON文件person.json读取并将其转换为Person对象。

调用readJsonFromFile()方法将触发读取操作:

JsonFileReader jsonFileReader = new JsonFileReader();
Person person = jsonFileReader.readJsonFromFile();

if (person != null) {
    System.out.println("姓名:" + person.getName());
    System.out.println("年龄:" + person.getAge());
}

执行上述代码后,将从person.json文件中读取数据并将其打印到控制台:

姓名:Alice
年龄:25

2.2 读取对象列表

假设你有一个JSON文件名为data.json,其中包含了一个对象列表,如下所示:

[
  {"name": "Alice", "age": 25},
  {"name": "Bob", "age": 30},
  {"name": "Charlie", "age": 35}
]

可以使用ObjectMapper类来读取JSON文件并将其转换为对象列表。

示例代码:

import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.databind.ObjectMapper;
import java.io.File;
import java.io.IOException;
import java.util.List;

public class JsonFileReader {
    public List<Person> readJsonFromFile() {
        ObjectMapper objectMapper = new ObjectMapper();

        try {
            File file = new File("data.json");
            List<Person> personList = objectMapper.readValue(file, new TypeReference<List<Person>>() {});
            System.out.println("JSON文件读取成功!");
            return personList;
        } catch (IOException e) {
            System.out.println("JSON文件读取失败:" + e.getMessage());
            return null;
        }
    }
}

在上述示例中,ObjectMapper类的readValue()方法接受两个参数:JSON文件对象和一个TypeReference对象,用于指定要转换的对象类型。在这个例子中,我们将JSON文件转换为List<Person>对象。

调用readJsonFromFile()方法将触发读取操作:

JsonFileReader jsonFileReader = new JsonFileReader();
List<Person> personList = jsonFileReader.readJsonFromFile();

if (personList != null) {
    for (Person person : personList) {
        System.out.println("姓名:" + person.getName());
        System.out.println("年龄:" + person.getAge());
    }
}

执行上述代码后,将从data.json文件中读取列表数据,并将每个人的姓名和年龄打印到控制台。

ESP8266是一款常用的WiFi模块,它支持通过MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议)连接到物联网服务器,实现设备之间的通信。以下是基本步骤: 1. **安装库**: - 首先,你需要在Arduino IDE中安装`PubSubClient`库,这是一个用于ESP8266与MQTT服务器通信的常用库。 2. **配置WiFi连接**: - 设置ESP8266连接到你的Wi-Fi网络,包括SSID和密码。 3. **设置MQTT客户端**: ```cpp #include <ESP8266WiFi.h> #include < PubSubClient.h > WiFiClient client; PubSubClient mqttClient(client, "your_broker_address", "username", "password"); ``` 这里"your_broker_address"替换为你的MQTT服务器地址,"username"和"password"则是登录账号和密码。 4. **连接到MQTT服务器**: ```cpp void connectToMqtt() { mqttClient.setServer("your_broker_address", 1883); while (!client.connected()) { if (client.connect("ESP8266Client")) { Serial.println("Connected to MQTT broker"); mqttClient.subscribe("$SYS/#"); // 订阅所有主题 } else { delay(5000); // 尝试重连,延时5秒 Serial.print("Attempting to reconnect..."); } } } ``` 5. **发布和订阅主题**: - 发布数据到主题: ```cpp void publish(String topic, String message) { mqttClient.publish(topic, message); Serial.println("Published message to " + topic); } ``` - 订阅并处理接收的数据: ```cpp void loop() { if (mqttClient.connected()) { mqttClient.loop(); // 处理接收到的消息 } // ...其他代码... } ``` 6. **断开连接**: ```cpp void stopMqtt() { mqttClient.disconnect(); Serial.println("Disconnected from MQTT broker"); } ``` 记得根据实际情况调整代码,并在`loop()`函数中添加相应的数据处理逻辑。当你有新的消息要发送或需要监听来自服务器的信息时,只需调用上述相应方法即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值