增删改查本地JSON

存储数据到JSON文件:

User u = new User();

MessageUtil.cache=”D:\\WSE\\Weixin\\”

String path = MessageUtil.cache + "WebContent\\config\\user.json";

JSONObject jo = JSONObject.fromObject(u);

FileWriter writer = new FileWriter(path, true);

writer.write(jo.toString() + ",\r\n");

writer.close();

存储时为续写模式,而非替换。

读取本地JSON文件:

String path = MessageUtil.cache + "WebContent\\config\\user.json";

String sets = ReadFile(path);

JSONArray ja = JSONArray.fromObject("[" + sets + "]");// 格式化成json对象

for (int i = 0; i < ja.size(); i++) {

User u = new User();

jo.get("KEY").toString();

//KEY为User存储时保存的属性。

Return u

}

ReadFile.java:

public static String ReadFile(String path) {

String laststr = "";

File file = new File(path);

BufferedReader reader = null;

try {

reader = new BufferedReader(new FileReader(file));

String tempString = null;

int line = 1;

// 一次读入一行,直到读入null为文件结束

while ((tempString = reader.readLine()) != null) {

// 显示行号

//System.out.println("line " + line + ": " + tempString);

laststr = laststr + tempString;

line++;

}

reader.close();

} catch (IOException e) {

e.printStackTrace();

} finally {

if (reader != null) {

try {

reader.close();

} catch (IOException e1) {

}

}

}

return laststr;

}

更新本地JSON:

根据条件找到匹配对象,设置更新属性,然后移除源对象,添加新对象,最后在转为JSONARRAY

String path = MessageUtil.cache + "WebContent\\config\\user.json";

String sets = ReadFile(path);// 读取本地json

JSONArray ja = JSONArray.fromObject("[" + sets + "]");// 格式化成json对象

JSONObject newjo = null;

for (int i = 0; i < ja.size(); i++) {

JSONObject jo = ja.getJSONObject(i);

if (jo.get("key").equals(key)) {//匹配条件

User u = (User) JSONObject.toBean(jo, User.class);

u.setToken(token);//需要更新的属性

u.setPassword(password); //需要更新的属性

newjo = JSONObject.fromObject(u);//转为JSON对象

ja.remove(i);// 如果token无效,则删除该记录,

i=i-1;

}

}

ja.add(newjo);

FileWriter fw = new FileWriter(path);

fw.write("");// json文件

fw.close();

FileWriter writer = new FileWriter(path, true);// 重新写入json

for (int i = 0; i < ja.size(); i++) {

writer.write(ja.get(i).toString() + ",\r\n");

}

writer.close();

删除本地JSON数据:

先转为JSONARRAY,进行移除,然后重新写入

String path = MessageUtil.cache + "WebContent\\config\\user.json";

String sets = ReadFile(path);// 读取本地json

JSONArray ja = JSONArray.fromObject("[" + sets + "]");// 格式化成json对象

JSONObject newjo = null;

for (int i = 0; i < ja.size(); i++) {

JSONObject jo = ja.getJSONObject(i);

if (jo.get("key").equals(key)) {

ja.remove(i);// 如果token无效,则删除该记录,

}

}

FileWriter fw;

try {

FileWriter writer = new FileWriter(path, true);// 重新写入json

fw = new FileWriter(path);

fw.write("");// json文件

fw.close();

for (int i = 0; i < ja.size(); i++) {

writer.write(ja.get(i).toString() + ",\r\n");

}

writer.close();

} catch (IOException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

时间: 2024-10-10 14:04:52

增删改查本地JSON的相关文章

利用LINQ to SQL 增删改查本地数据库

C#新人,博客园第一篇博文,希望大家多多指教. 最近趁项目空隙,学习了LINQ,其强大高效易读的数据操作方式令人印象深刻.特别是LINQ to SQL,让用户可以像操作内存对象一样操作SQL数据库.在阅读了<深入理解c#>和参考以下四篇博文后,自己摸索,完成了创建本地SQL数据库和数据表,VS连接数据库,到利用LINQ to SQL增删改查数据库表中信息. SQL服务器安装:http://www.downcc.com/tech/4135.html SQL数据库和数据表格创建:http://bl

React__TodoList 简单增删改查—本地存储-案例

1 import React, { Component } from 'react' 2 3 export default class todolist extends Component { 4 constructor(props) { 5 super() 6 this.state = { 7 name: [] 9 } 10 } 12 //refs 13 todoonclick = () => { 14 if (this.refs.inputmy.value === '') { 15 aler

asp.net中利用JSON进行增删改查中运用到的方法

//asp.net中 利用JSON进行操作, //增加: //当点击"增加链接的时候",弹出增加信息窗口,然后,在窗体中输入完整信息,点击提交按钮. //这里我们需要考虑这些:我会进行异步提交,使用jquery中的方法,$.post("网页名",JSON,callback); //JSON的写法:{"name":name,"id":id},那我们对其进行假设,比方说,表单中的textbox很多,需要我们填写的信息 //也很多,

javascript json对象操作(基本增删改查)

/** * Json对象操作,增删改查 * * @author lellansin * @blog www.lellansin.com * @version 0.1 * * 解决一些常见的问题 * get/set 解决获取和设置时,无节点中断的问题 * create 可以创建多级节点,若存在则覆盖新值 * delete 删除节点及其子节点 * print_r 格式化输出对象(调试用) * 实例见底部 */ function Json() { } /** * 获取Json对象中的某个节点 * 例如

mongoDB (mongoose、增删改查、聚合、索引、连接、备份与恢复、监控等等)

MongoDB - 简介 官网:https://www.mongodb.com/ MongoDB 是一个基于分布式文件存储的数据库,由 C++ 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的. MongoDB - 安装及运行 下载 07/05/2017 Current Stable Release (3.4.6) https://www.mongodb.com/dow

MongoDB 3.0.6 安装 增删改查

下载 安装包MSI http://yunpan.cn/cmhHdTPkXZRM2  访问密码 9b6c 上边提供的是 MongoDB 3.0.6 64Bit 的安装包 安装 如果不想直接安装在C盘..就要选择自定义安装喽.. 就是选择全部安装和自定义的那一步..全部安装是默认安装C盘的.. 我这里是安装到 D:\Program Files\MongoDB\MongoDB 的.. 需要在 D:\Program Files\MongoDB 下新建 Log 文件夹..并在Log下建立 Log.txt

SSHE框架整合(增删改查)

1.前期准备:jar包(c3p0.jdbc ,各个框架) web.xml文件:spring的   转码的,和Struts2的过滤器 <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee&qu

基于SSM实现的MySQL增删改查

之前自学完了JAVA基础,一直以来也没有做什么好玩的项目,最近暑假,时间上比较空闲,所以又学习了一下最近在企业实际应用中比较流行的SSM框架,以此为基础,通过网络课程,学习编写了一个基于SSM实现的MySQL增删改查的网站,好了废话不多说,下面介绍一下项目. 首先,页面的UI是使用了Bootstrap框架快速搭建的,这个框架还是比较好用的,不但快速,而且美观,风格偏扁平化.而且对于我这种英文渣渣来说,有中文的帮助文档,简直不要太好上手,然后搭建好的大致效果图就如1-1所示,当然搭建好的只是静态页

JS源生代码“增删改查”之增

51呢最近在做一个管理数据的,第一次接触到用JS的源代码去实现一些功能,才知道网页里的许多功能都是依赖于“增删改查”完成的,下面的几张图片就是对于增的演示: 下面是有关HTML的代码:这个主要是弹窗部分的HTML代码 <div id="addDialog"> <div id="div11"> <form action="" id="from"> <table class="b