Asp.Net MVC 读取json文件
有些系统上面的配置可以做成config里面的appsetting。这里要求写在json文件里面。
首先 添加命名空间

using Newtonsoft.Json;
using System.IO;
using Newtonsoft.Json.Linq;
using System.Web;
下面是我json文件里面的内容 因为西门下面的序号是 变动的就写在配置文件里面也好修改
{
"StatisticalChart": {
"": "/Common/CountReport/DefaultStatis",
"": "/Common/CountReport/CustomerManagerStatis",
"": "/Common/CountReport/FirstExamineStatis",
"": "/Common/CountReport/QualityCheckStatis",
"": "/Common/CountReport/ElectricFinalCheckStatis",
"": "/Common/CountReport/ExecutiveDirectorStatis"
},
"NameGetCode":{
"Default": "",
"CustomerManager": "",
"FirstExamine": "",
"QualityCheck": "",
"ElectricFinalCheck": "",
"ExecutiveDirector": ""
}
}
下面是读取StatisticalChart节点里面的内容 power权限参数 用户登录之后获得。
/// <summary>
/// 通过角色读取配置文件返回地址
/// </summary>
/// <param name="power">权限编号</param>
/// <returns></returns>
public static string GetUrlByPower(string power)
{
string url = "";
try
{
//文件路径
string jsonfile = HttpContext.Current.Server.MapPath($"\\App_Data\\config\\StatisticalChartConfig.json");
//打开文件
System.IO.StreamReader file = System.IO.File.OpenText(jsonfile);
//加载问卷
JsonTextReader reader = new JsonTextReader(file);
//转化为JObject
JObject ojb = (JObject)JToken.ReadFrom(reader);
//读取StatisticalChart节点
var list = ojb["StatisticalChart"].ToString();
JObject jo = (JObject)JsonConvert.DeserializeObject(list);
var dat = jo[power];
if (dat == null)
url = "";
else
url = dat.ToString();
}
catch (Exception e)
{
url = "";
throw new Exception($"初始化JSON流程配置失败:{e.Message}");
}
return url;
}
另外一种 中国省市县的json文件

读取的方法(我是通过身份证号码获取信息用到的)
//读取json文件获取代码对应的省市县
string jsonfile =HttpContext.Current.Server.MapPath($"\\App_Data\\Config\\AreasData.json");
StreamReader file = File.OpenText(jsonfile);
JsonTextReader reader = new JsonTextReader(file);
var obj = JToken.ReadFrom(reader).ToList();
for (int i = ; i < obj.Count; i++)
{
JObject jo = (JObject)JsonConvert.DeserializeObject(obj[i].ToString());
if (jo["zoneCode"].ToString() == AreasCodess)
{
var Data = new AreasCode()
{
Province = jo["province"].ToString(),
ProvinceCode = jo["provinceCode"].ToString(),
City = jo["city"].ToString(),
CityCode = jo["cityCode"].ToString(),
Country = jo["zone"].ToString(),
CountryCode = jo["zoneCode"].ToString()
};
list.Add(Data);
break;
} }
AreasCode是个实体类 接收参数的Model,AreasCodess是区域代码。读取json文件代码就这些 全面几步都是一样的 后面要看具体的json文件格式,就跟Ajax一样 返回来数据类型 是后台决定的你才好解析!
获取身份证信息也贴上吧,后面用到又来拿
/// <summary>
/// 获取身份证信息
/// </summary>
/// <param name="identityCard">身份证号码</param>
/// <param name="ageIsTrue">显示年龄是否是真实大小(当前年份减去出生年份 月份 日期都要计算)</param>
/// <returns>List->IDCard模型</returns>
public static List<IDCard> GetIDCardInfo(string identityCard, bool ageIsTrue = true)
{ if (string.IsNullOrEmpty(identityCard))//为空返回null
return null;
else
{
if (identityCard.Length != && identityCard.Length != )//身份证号码只能为15位或18位其它不合法
return null;
}
List<IDCard> dCards = new List<IDCard>();
IDCard card = new IDCard();
string strSex = string.Empty;
//530326 1994 1201 2521
if (identityCard.Length == )//处理18位的身份证号码从号码中得到生日和性别代码
{
//出身年月日
card.Birthday = identityCard.Substring(, ) + "-" + identityCard.Substring(, ) + "-" + identityCard.Substring(, );
strSex = identityCard.Substring(, );//
}
//530323 670401 001的含义; 530为云南,03为曲靖 ,23是师宗,出生日期为1967年4月1日,顺序号为001。
if (identityCard.Length == )
{
card.Birthday = "" + identityCard.Substring(, ) + "-" + identityCard.Substring(, ) + "-" + identityCard.Substring(, );
//性别代码
strSex = identityCard.Substring(, );
} card.Age = CalculateAge(card.Birthday, ageIsTrue);//根据生日计算年龄
if (int.Parse(strSex) % == )//性别代码为偶数是女性奇数为男性
card.Sex = "女";
else
card.Sex = "男";
string AreasCodess = identityCard.Substring(, );
List<AreasCode> list = new List<AreasCode>();
try
{
//读取json文件获取代码对应的省市县
string jsonfile =HttpContext.Current.Server.MapPath($"\\App_Data\\Config\\AreasData.json");
StreamReader file = File.OpenText(jsonfile);
JsonTextReader reader = new JsonTextReader(file);
var obj = JToken.ReadFrom(reader).ToList();
for (int i = ; i < obj.Count; i++)
{
JObject jo = (JObject)JsonConvert.DeserializeObject(obj[i].ToString());
if (jo["zoneCode"].ToString() == AreasCodess)
{
var Data = new AreasCode()
{
Province = jo["province"].ToString(),
ProvinceCode = jo["provinceCode"].ToString(),
City = jo["city"].ToString(),
CityCode = jo["cityCode"].ToString(),
Country = jo["zone"].ToString(),
CountryCode = jo["zoneCode"].ToString()
};
list.Add(Data);
break;
} }
if (list.Count > )
{
card.Province = list[].Province;
card.ProvinceCode = list[].ProvinceCode;
card.City = list[].City;
card.CityCode = list[].CityCode;
card.Country = list[].Country;
card.AreasCode = list[].CountryCode;
card.AddressAreas = list[].Province + list[].City + list[].Country;
}
dCards.Add(card);
return dCards;
}
catch (Exception xx)
{
dCards[].Msg = xx.Message;
return dCards;
}
} /// <summary>
/// 身份证信息实体类
/// </summary>
public class IDCard
{
/// <summary>
/// 年龄
/// </summary>
public int Age { get; set; }
/// <summary>
/// 性别
/// </summary>
public string Sex { get; set; }
/// <summary>
/// 生日
/// </summary>
public string Birthday { get; set; }
/// <summary>
/// 省份
/// </summary>
public string Province { get; set; }
/// <summary>
/// 市区
/// </summary>
public string City { get; set; }
/// <summary>
/// 县城
/// </summary>
public string Country { get; set; }
/// <summary>
/// 身份证所在区域(省市县)
/// </summary>
public string AddressAreas { get; set; }
/// <summary>
/// 区域代码
/// </summary>
public string AreasCode { get; set; }
/// <summary>
/// 省代码
/// </summary>
public string ProvinceCode { get; set; }
/// <summary>
/// 县/区代码
/// </summary>
public string CityCode { get; set; }
/// <summary>
/// 信息
/// </summary>
public string Msg { get; set; }
/// <summary>
/// 状态
/// </summary>
public string Status { get; set; } } /// <summary>
/// 实体类(省市县跟代码)身份证前6位数字
/// </summary>
public class AreasCode
{
/// <summary>
/// 省份
/// </summary>
public string Province { get; set; }
/// <summary>
/// 省份代码
/// </summary>
public string ProvinceCode { get; set; }
/// <summary>
/// 市
/// </summary>
public string City { get; set; }
/// <summary>
/// 市/区 代码
/// </summary>
public string CityCode { get; set; }
/// <summary>
/// 县
/// </summary>
public string Country { get; set; }
/// <summary>
/// 县代码
/// </summary>
public string CountryCode { get; set; }
} /// <summary>
/// 根据出生日期,计算精确的年龄
/// </summary>
/// <param name="birthDate">生日</param>
/// <returns>年龄</returns>
public static int CalculateAge(string birthDay, bool ageIs = true)
{
DateTime birthDate = DateTime.Parse(birthDay);
DateTime nowDateTime = DateTime.Now;
int age = nowDateTime.Year - birthDate.Year;
//再考虑月、天的因素
if (ageIs)
{
if (nowDateTime.Month < birthDate.Month || (nowDateTime.Month == birthDate.Month && nowDateTime.Day < birthDate.Day))
{
age--;
}
}
return age;
}
Asp.Net MVC 读取json文件的更多相关文章
- [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传
原文 [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传 Fine Uploader(http://fineuploader.com/)是一个实现 ajax 上传文件 ...
- ASP.NET Core appsettings.json 文件
ASP.NET Core appsettings.json 文件 在本节中,我们将讨论 ASP.NET Core 项目中appsettings.json文件的重要性. 在以前的 ASP.NET 版本中 ...
- jquery无法读取json文件问题
jquery无法读取json文件,如:user.json文件无法读取.把user.json文件的后缀名修改为aspx,文件内容不变,则可以读取~ 原理不懂!~~
- Unity 用C#脚本读取JSON文件数据
读取JSON文件数据网上有很多方法吗,这里采用SimpleJSON,关于SimpleJSON的介绍参考以下链接:http://wiki.unity3d.com/index.php/SimpleJSON ...
- cocos2d-x 读取 json 文件并用 jsoncpp 做解析
一码胜万言(请看注释) CclUtil.h // // CclUtil.h // PracticeDemo // // Created by kodeyang on 8/1/13. // // #if ...
- jQuery读取json文件,实现省市区/县(国标)三级联动
最近做一个微信项目,需要用户填写所在的省市区/县,决定使用jQuery读取json文件来实现省市区/县的联动. 其实很简单,jQuery文档也有详细解释: 代码如下: html <table w ...
- jqery ajax读取json文件
json文件数据 [ {"name":"哈哈··","email":"邮箱01","gender": ...
- spring注解读取json文件
开发时候在接口没有提供的时候,可以用json文件提前模拟接口数据 1.service层 package com.syp.spring.service; import java.io.File; imp ...
- Android - 读取JSON文件数据
Android读取JSON文件数据 JSON - JavaScript Object Notation 是一种存储和交换文本信息的语法. JSON对象在花括号中书写.用逗号来分隔值. JSON数组在方 ...
随机推荐
- javaScript Event Loop + NodeJs问题解析
http://www.ruanyifeng.com/blog/2014/10/event-loop.html https://github.com/ElemeFE/node-interview/tre ...
- 【RL-TCPnet网络教程】第17章 RL-TCPnet之UDP通信
第17章 RL-TCPnet之UDP通信 本章节为大家讲解RL-TCPnet的UDP通信实现,学习本章节前,务必要优先学习第16章UDP用户数据报协议基础知识.有了这些基础知识之后,再搞本章 ...
- [Swift]LeetCode239. 滑动窗口最大值 | Sliding Window Maximum
Given an array nums, there is a sliding window of size k which is moving from the very left of the a ...
- [Swift]LeetCode566. 重塑矩阵 | Reshape the Matrix
In MATLAB, there is a very useful function called 'reshape', which can reshape a matrix into a new o ...
- [Swift]LeetCode572. 另一个树的子树 | Subtree of Another Tree
Given two non-empty binary trees s and t, check whether tree t has exactly the same structure and no ...
- [Swift]LeetCode847. 访问所有节点的最短路径 | Shortest Path Visiting All Nodes
An undirected, connected graph of N nodes (labeled 0, 1, 2, ..., N-1) is given as graph. graph.lengt ...
- MyEclipse设置编码格式
1.设置项目编码格式,右键项目,Properties 选择第一个 2.设置软件编码格式,windows---->Preferences打开"首选项"对话框
- Nginx 动静分离与负载均衡的实现
一.前提 企业中,随着用户的增长,数据量也几乎成几何增长,数据越来越大,随之也就出现了各种应用的瓶颈问题. 问题出现了,我们就得想办法解决,一般网站环境,均会使用LAMP或者LNMP,而我们对于网站环 ...
- ubuntu18下安装docker
1.通过指令检查linux内核 uname -a 可以看到大于3.10版本 2.检查是否存在对应目录 ls -l /sys/class/misc/device-mapper 3. apt-get指令 ...
- 【Spark篇】---SparkSQL on Hive的配置和使用
一.前述 Spark on Hive: Hive只作为储存角色,Spark负责sql解析优化,执行. 二.具体配置 1.在Spark客户端配置Hive On Spark 在Spark客户端安装包下sp ...