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. SVN代码冲突解决方案小集合

    对于刚接触svn的人来说,svn冲突后,不能提交是件让人很郁闷的事情.最让人郁闷的事,是代码间的覆盖.你把我代码盖了,我会很火大的.谁把谁的盖了都不爽. 为什么会出现代码冲突问题呢,因为不同的人,同时 ...

  2. OpenCascade Primitives BRep-Cone

    OpenCascade Primitives BRep-Cone eryar@163.com Abstract. BRep is short for Boundary Representation. ...

  3. WPF datagrid 加入图片

    <DataGridTemplateColumn Header="图像" Width="SizeToCells"> <DataGridTempl ...

  4. SqlServer用sql对表名、字段做修改

    1.重命名表  下例将表 users重命名为 userdd.  EXEC sp_rename 'users', 'userdd'  2. 重命名列  下例将表 userdd中的列 sex 重命名为 s ...

  5. 如何在文章/随笔中添加可运行的js代码

    <script type="text/javascript"> alert("你知道我是怎么弹出的吗?"); </script> 看大神 ...

  6. Hibernate的数据查找,添加!

    1.首先看一下测试数据库的物理模型 2.测试所需要的Hibernate的jar包 3.数据库的sql /*=============================================== ...

  7. .Net 转战 Android 4.4 日常笔记目录

    .Net 转战 Android 4.4 日常笔记(1)--工具及环境搭建 .Net 转战 Android 4.4 日常笔记(2)--HelloWorld入门程序 .Net 转战 Android 4.4 ...

  8. make things simple

    以前看过一篇文章,具体内容不记得了,只记得它的结论了:懒是人类进步的源动力.当时觉得结论有点新颖,文中列举了大量的实例证明这个结论,其中重点强调了计算机学科.我本身从事算是计算机相关的工作,对文中的部 ...

  9. 将DataTable转换成CSV文件

    DataTable用于在.net项目中,用于缓存数据,DataTable表示内存中数据的一个表.CSV文件最早用在简单的数据库里,由于其格式简单,并具备很强的开放性,所以起初被扫图家用作自己图集的标记 ...

  10. jquery实现分页功能

    RT,不是很难,但是感觉代码一点都不简洁,就是多加点判断,直接上代码了. HTML部分: <div class = "container-fluid"> <div ...