1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Web;
  5. using System.Web.UI;
  6. using System.Web.UI.WebControls;
  7. using System.IO;
  8. using System.Text;
  9. using Newtonsoft.Json;
  10. using com.zjpx.model;
  11. using System.Collections;
  12. using Newtonsoft.Json.Converters;
  13. namespace web
  14. {
  15. public partial class testJson : System.Web.UI.Page
  16. {
  17. protected void Page_Load(object sender, EventArgs e)
  18. {
  19. ConfigFileModel cfm = new ConfigFileModel();  //实体模型类
  20. cfm.CreateDate = "2012-02-23";
  21. cfm.FileName = "test.txt";
  22. //可以操作集合
  23. Hashtable ht = new Hashtable();
  24. ht.Add("hs_name", "alex");
  25. ht.Add("hs_pwd", "ggg");
  26. //序列化
  27. string js1 = JsonConvert.SerializeObject(cfm);
  28. string js2 = JsonConvert.SerializeObject(ht);
  29. Response.Write(js1);
  30. Response.Write("<br/>");
  31. Response.Write(js2);
  32. //"{\"FileName\":\"test.txt\",\"CreateDate\":\"2012-02-23\"}"
  33. //"{\"hs_pwd\":\"ggg\",\"hs_name\":\"alex\"}"
  34. //反序列化
  35. ConfigFileModel debc1 = JsonConvert.DeserializeObject<ConfigFileModel>(js1);
  36. ConfigFileModel debc2 = JsonConvert.DeserializeObject<ConfigFileModel>(js2);
  37. //找到服务器物理路径
  38. //string serverAppPath = Request.PhysicalApplicationPath.ToString();
  39. string serverAppPath = @"d:\";
  40. //构成配置文件路径
  41. string con_file_path =@""+ serverAppPath + @"config.json";
  42. if (!File.Exists(con_file_path))
  43. {
  44. File.Create(con_file_path);
  45. }
  46. //把模型数据写到文件
  47. using (StreamWriter sw = new StreamWriter(con_file_path))
  48. {
  49. try
  50. {
  51. JsonSerializer serializer = new JsonSerializer();
  52. serializer.Converters.Add(new JavaScriptDateTimeConverter());
  53. serializer.NullValueHandling = NullValueHandling.Ignore;
  54. //构建Json.net的写入流
  55. JsonWriter writer = new JsonTextWriter(sw);
  56. //把模型数据序列化并写入Json.net的JsonWriter流中
  57. serializer.Serialize(writer, cfm);
  58. //ser.Serialize(writer, ht);
  59. writer.Close();
  60. sw.Close();
  61. }
  62. }
  63. catch (Exception ex)
  64. {
  65. ex.Message.ToString();
  66. }
  67. //读取json文件
  68. using (StreamReader sr = new StreamReader(con_file_path))
  69. {
  70. try
  71. {
  72. JsonSerializer serializer = new JsonSerializer();
  73. serializer.Converters.Add(new JavaScriptDateTimeConverter());
  74. serializer.NullValueHandling = NullValueHandling.Ignore;
  75. //构建Json.net的读取流
  76. JsonReader reader = new JsonTextReader(sr);
  77. //对读取出的Json.net的reader流进行反序列化,并装载到模型中
  78. cfm = serializer.Deserialize<ConfigFileModel>(reader);
  79. Response.Write("<br/>");
  80. Response.Write(cfm.FileName+", "+cfm.CreateDate);
  81. }
  82. catch (Exception ex)
  83. {
  84. ex.Message.ToString();
  85. }
  86. }
  87. }
  88. }
  89. public class ConfigFileModel
  90. {
  91. public ConfigFileModel() { }
  92. string _fileName;
  93. public string FileName
  94. {
  95. get { return _fileName; }
  96. set { _fileName = value; }
  97. }
  98. string _createDate;
  99. public string CreateDate
  100. {
  101. get { return _createDate; }
  102. set { _createDate = value; }
  103. }
  104. }
  105. }

Json.NET读取和写入Json文件的更多相关文章

  1. python读取并写入mat文件

    用matlab生成一个示例mat文件: clear;clc matrix1 = magic(5); matrix2 = magic(6); save matData.mat 用python3读取并写入 ...

  2. Asp.net读取和写入txt文件方法(实例)!

    Asp.NET读取和写入txt文件方法(实例)! [程序第一行的引入命名空间文件 - 参考] System; using System.Collections; using System.Config ...

  3. java读取数据写入txt文件并将读取txt文件写入另外一个表

    package com.xsw.test; import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.F ...

  4. python读取和写入csv文件

    读取csv文件: def readCsv(): rows=[] with file(r'E:\py\py01\Data\system.csv','rb') as f: reads=csv.reader ...

  5. C#读取和写入XML文件

    关于xml是属于一个比较重要的东西,在平时开发的过程中,这块内容最主要的是要掌握XML内容的读取和写入操作. 一.什么是XML? XML 指可扩展标记语言(EXtensible Markup Lang ...

  6. python之读取和写入csv文件

    写入csv文件源码: #输出数据写入CSV文件 import csv data = [ ("Mike", "male", 24), ("Lee&quo ...

  7. php下载文件,解压文件,读取并写入新文件

    以下代码都是本人在工作中遇到的问题,并完成的具体代码和注释,不多说,直接上代码: <?php      //组织链接      $dataurl = "http://118.194.2 ...

  8. C语言实现<读取>和<写入> *.ini文件(转)

    原地址:https://blog.csdn.net/niha1993825jian/article/details/41086403 #include <stdio.h> #include ...

  9. Java——读取和写入txt文件

    package com.java.test.a; import java.io.BufferedReader; import java.io.BufferedWriter; import java.i ...

随机推荐

  1. java基础-多线程执行

    package Thanqi; public class TestApple implements Runnable{ //苹果的数量 private int count = 5; //拿苹果 //s ...

  2. hudson部署过程

    hudson部署过程: java安装 http://developer.51cto.com/art/201504/470683.htm tomcat安装 http://blog.csdn.net/hu ...

  3. SQL 截取字符串

    以下代码演示的是除去字符串后四位 ,) 下面是SUBSTRING的解释 SUBSTRING ( expression ,start , length ) 第一个参数是字符串,第二个是起始位置,第三个是 ...

  4. # Hawk:开源贡献计划,设计,反思

    Hawk在发布之后,收到了不少朋友的感谢和使用反馈,沙漠君表示非常开心.软件肯定有很多的问题和不足,还有很多可扩展的空间,因此我希望更多的朋友,能够参与到改进Hawk的计划中来,为开源世界作出努力. ...

  5. webapp应用---cordova.js 3.7.0插件安装总结

    今天是2014年的最后一天,年终总结什么的就不写了.记录一下今天的工作内容.如果不知道phoneGap,那么就不需要往下看了,phoneGap现在已经叫cordova了,叫什么不重要,重要的是它对we ...

  6. 一款开源免费跨浏览器的视频播放器--videojs使用介绍

    最近项目中的视频功能,需要做到浏览器全兼容,所以之前用html5实现的视频功能就需要进行改造了.在网上翻了个遍,试来试去,在所有的视频播放器中,就数它最实际了.首先我们来看看它的优点: 1.它是开源免 ...

  7. SQL Server 通过重建方式还原 master 数据库

    1,备份master数据库 2,停止服务,直接删除master数据文件 3,用安装程序重建master数据文件 控制台下进入安装目录就不说了 D:\SetUp\sqlserver2012>Set ...

  8. Spring-Boot - 初步搭建

    official document:http://projects.spring.io/spring-boot/ 项目代码: https://github.com/chenxing12/springb ...

  9. CDH集群主节点宕机恢复

    1       情况概述 公司的开发集群在周末莫名其妙的主节点Hadoop-1的启动固态盘挂了,由于CM.HDFS的NameNode.HBase的Master都安装在Hadoop-1,导致了整个集群都 ...

  10. 创建ASP.NET Core MVC应用程序(6)-添加验证

    创建ASP.NET Core MVC应用程序(6)-添加验证 DRY原则 DRY("Don't Repeat Yourself")是MVC的设计原则之一.ASP.NET MVC鼓励 ...