C# Newtonsoft增删改查(本地存储)(简单便捷)(拿来即用)
调用方法:
LocalSetupHelper.SetData(Sss.维护, "密码", "123456"); //保存
var c=LocalSetupHelper.GetData(Sss.前台, "密码"); 获取
LocalSetupHelper.RemovePropertyName(Sss.前台, "密码"); //清除子节点
LocalSetupHelper.RemovePropertyName(Sss.前台); 清除父节点
enum Sss
{
维护,
前台,
}
输出格式:
{
"前台": {
"密码": "123456",
},
"维护": {
"密码": "123456"
}
}
Demo: 拿来直接用

public static class LocalSetupHelper
{
#region 字段
/// <summary>
/// json文本
/// </summary>
private static string json;
/// <summary>
/// 指定保存路径
/// </summary>
public static string path { get; set; }
#endregion #region 构造函数
static LocalSetupHelper()
{
if (string.IsNullOrEmpty(path))
{
string currentDirectory = Directory.GetCurrentDirectory();
path = currentDirectory + "\\LocalSetup.Data";
}
if (!File.Exists(path))
{
FileStream fs = File.Create(path);
fs.Close();
}
json = LoadFromFile(path);
}
#endregion #region 获取
/// <summary>
/// 获取数据
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点</param>
/// <returns></returns>
public static object GetData(Enum id, string propertyName)
{
return GetDatas(id, propertyName);
}
#endregion #region 保存
/// <summary>
/// 保存数据
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点名称</param>
/// <param name="propertyValue">子节点值</param>
public static void SetData(Enum id, string propertyName, object propertyValue)
{
SetData(ref json, id, propertyName, propertyValue); }
#endregion #region 移除
/// <summary>
/// 移除
/// </summary>
/// <param name="id">父节点</param>
/// <param name="propertyName">子节点</param>
public static void RemovePropertyName(Enum id, string propertyName = null)
{
Remove(ref json, id, propertyName); }
/// <summary>
/// 清空数据
/// </summary>
public static void ClearData()
{
json = string.Empty;
SaveToFile(path);
}
#endregion #region 内部方法
private static void Add(ref string json, string propertyName, object propertyValue)
{
JObject jsonObj = JObject.Parse(json);
jsonObj.Add(propertyName, JToken.FromObject(propertyValue));
json = jsonObj.ToString();
} private static void Update(ref string json, string propertyName, object propertyValue)
{
JObject jsonObj = JObject.Parse(json);
jsonObj[propertyName] = JToken.FromObject(propertyValue);
json = jsonObj.ToString();
} private static object GetValue(string json, string propertyName)
{
dynamic jsonObj = JsonConvert.DeserializeObject(json);
return jsonObj[propertyName];
} private static void Remove(ref string json, Enum id, string propertyName = null)
{
dynamic jsonObj = JsonConvert.DeserializeObject(json);
if (propertyName == null)
{
jsonObj.Remove(propertyName);
}
else
{
//jsonObj["总台"].Value<JObject>().Remove("账号");
jsonObj[id.ToString()].Remove(propertyName);//13.0版本
}
json = JsonConvert.SerializeObject(jsonObj);
SaveToFile(path);
} private static void SetData(ref string json, Enum id, string propertyName, object propertyValue)
{
JObject jsonObj;
if (!string.IsNullOrEmpty(json))
{
jsonObj = JObject.Parse(json);
}
else
{
jsonObj = new JObject();
} if (jsonObj[id.ToString()] == null)
{
jsonObj.Add(id.ToString(), new JObject());
}
jsonObj[id.ToString()][propertyName] = JToken.FromObject(propertyValue); json = jsonObj.ToString();
SaveToFile(path);
} private static object GetDatas(Enum id, string propertyName)
{
if (!string.IsNullOrEmpty(json))
{
JObject jsonObj = (JObject)JsonConvert.DeserializeObject(json);
JObject frontEndObj = jsonObj[id.ToString()] as JObject;
if (frontEndObj!=null&&frontEndObj.ContainsKey(propertyName))
{
return jsonObj[id.ToString()][propertyName];
}
}
return null;
} private static void SaveToFile(string filePath)
{
using (var fileStream = new FileStream(filePath, FileMode.Create, FileAccess.Write, FileShare.None))
{
using (var streamWriter = new StreamWriter(fileStream))
{
streamWriter.Write(json);
}
}
} private static string LoadFromFile(string filePath)
{
string[] lines = File.ReadAllLines(filePath);
return string.Join("", lines);
}
#endregion
}
当然也有这种节点的
{
"密码": "123456",
"密码xxx": "123456"
}
可以参考前面的连接 :(Newtonsoft)Json增删改查(这是单个对象) - 22222220 - 博客园 (cnblogs.com)
C# Newtonsoft增删改查(本地存储)(简单便捷)(拿来即用)的更多相关文章
- 如何创建数据库以及MySQL增删改查命令的简单运用
在已经安装好MySQL的前提下 1.在Windows打开命令提示符窗口,输入命令启动MySQL命令行工具并登入root用户:mysql -h localhost -u root -p 2.输入密码后, ...
- C#中对sqlserver进行增删改查操作(简单易懂)
1.添加引用using System.Data;using System.Data.SqlData; 2.建立于数据库的连接,建议将它做成一个方法,方便多次利用.string sqlconnectio ...
- MyBatis对数据库的增删改查操作,简单演示样例
之前一直有用Hibernate进行开发.近期公司在使用Mybatis.依据网上的演示样例,做了一个简单的Demo,以便日后复习 使用XMl方式映射sql语句 整体结构例如以下图 watermark/2 ...
- easyui+nodejs+sqlserver增删改查实现
用到的模块或者技术: Express: http://www.expressjs.com.cn/4x/api.html#express Easyui: http://www.jeasyui.com/d ...
- QMap 的增删改查
map 是一种数据容器,它提供一种由key 到 value 的映射.map 的key 是唯一的, 也是有序的.map 通常由近似平衡的红黑树来实现.key 的有序性,使得插入,查找节点比较有效.map ...
- MyBatis-单表的增删改查(CRUD)操作
在学习MyBatis的单表的增删改查操作之前,还是再次熟悉下MyBatis这个框架,只有对其熟悉的情况下,才能很好的使用,灵活的开发. MyBatis优点: ...
- Spring Date JPA实现增删改查
1.新建一个Cart类 package com.entity; public class Cart { private int id; private int userId; private int ...
- 12 Servlet_04 Servlet增删改查 静态页面与动态页面 EL表达式 table表格的一些样式
今天学习了servlet的增删改查: 存储数据 setAttribute(String name,Object obj );获取数据 getAttribute(String name);删除数据 re ...
- Mybatis-plus实现数据库的增删改查操作
目录 1.MybatisPlus简介 2.MybatisPlus注解介绍 3.常用方法 4.SpringBoot整合MybatisPlus实现增删改查的一个简单Demo 5.参考资料 1.Mybati ...
- 使用Mongoose类库实现简单的增删改查
使用Mongoose类库实现简单的增删改查 Mongoose是在nodejs环境中对MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为javascript对象供我们使用. M ...
随机推荐
- CSS 样式表引入的3种方式
CSS 全称为层叠样式表(Cascading Style Sheet),用来定义 HTML 文件最终显示的外观.HTML 文件里引入 CSS 样式有3种方式: 外部样式表.内部样式表.行内样式. 外部 ...
- WEB服务与NGINX(22)- nginx的七层负载均衡功能
目录 1. NGINX实现负载均衡功能 1.1 nginx负载均衡概述 1.2 nginx实现http的负载均衡 1.2.1 nginx基于http负载均衡场景配置 1.2.1.1 负载均衡相关参数 ...
- python教程3.3:字符和编码
1.二进制 计算机只能存储和识别二进制,但是人类常用的字母.数字.汉字怎么用计算机存储和识别呢? 人类强行约定一个对应表,把数字.字母和数字进行对应上,这样就可以用二进制表示字母和数字了. 2.ASC ...
- rocketmq 搭建配置
broker组1: # NameServer地址 namesrvAddr=192.168.1.100: 9876;192.168.1.101: 9876 # 集群名称 brokerClusterNam ...
- Json.NET Converting between JSON and XML
Json.NET supports converting JSON to XML and vice versa using the XmlNodeConverter. Elements, attrib ...
- navicat 如何调整查询区域字体大小
Navicat是一套快速.可靠和全面的数据库管理工具,专门用于简化数据库管理和降低管理成本.Navicat图形界面直观,提供简便的管理方法,设计和操作MySQL.MariaDB.SQL Server. ...
- win10离线安装.net3.5失败的解决方案
简介: 问题:有时候需要离线安装.net3.5环境,网上的教程一般都是通过NetFx3.cab进行离线安装,但有时候会出现离线安装失败,比如: by~MaQaQ 2024-06-04 分析: 1.先关 ...
- 还在拼冗长的WhereIf吗?100行代码解放这个操作
通常我们在做一些数据过滤的操作的时候,经常需要做一些判断再进行是否要对其进行条件过滤. 普通做法 最原始的做法我们是先通过If()判断是否需要进行数据过滤,然后再对数据源使用Where来过滤数据. 示 ...
- 「TAOI-2」Ciallo~(∠・ω< )⌒★ 题解
「TAOI-2」Ciallo-(∠・ω< )⌒★ 题解 不难发现,答案可以分成两种: 整段的 中间删一点,两端凑一起的 考虑分开计算贡献. 如果 \(s\) 中存在子串等于 \(t\),那么自然 ...
- kettle从入门到精通 第二十一课 kettle Carte服务器
1.相关配置文件 jdbc.properties保存在simple-jndi目录下,这个文件用来存储JNDI连接对象的连接参数.Kettle可以用JNDI的方式来引用JDBC连接参数,如IP地址.用户 ...