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数组在方 ...
随机推荐
- mysql 删除指定字符
mysql 删除指定字符 1.1 前言 实际需求中如果想删除指定的字符,一般需要使用到trim函数.trim函数默认删除字符的前后空格,如果想指定删除特定字符,则需要使用一下语句进行声明 ...
- 算法与数据结构(八) AOV网的关键路径(Swift版)
上篇博客我们介绍了AOV网的拓扑序列,请参考<数据结构(七) AOV网的拓扑排序(Swift面向对象版)>.拓扑序列中包括项目的每个结点,沿着拓扑序列将项目进行下去是肯定可以将项目完成的, ...
- HashMap 相关面试题及其解答
Q:HashMap 的数据结构? A:哈希表结构(链表散列:数组+链表)实现,结合数组和链表的优点.当链表长度超过 8 时,链表转换为红黑树. transient Node<K,V>[] ...
- 使用SIP Servlet为Java EE添加语音功能
会话发起协议(Session Initiation Protocol,SIP)是一种信号传输协议,用于建立.修改和终止两个端点之间的会话.SIP 可用于建立 两方呼叫.多方呼叫,或者甚至 Intern ...
- #Java学习之路——基础阶段(第三篇)
我的学习阶段是跟着CZBK黑马的双源课程,学习目标以及博客是为了审查自己的学习情况,毕竟看一遍,敲一遍,和自己归纳总结一遍有着很大的区别,在此期间我会参杂Java疯狂讲义(第四版)里面的内容. 前言: ...
- [Swift]LeetCode328. 奇偶链表 | Odd Even Linked List
Given a singly linked list, group all odd nodes together followed by the even nodes. Please note her ...
- [Swift]LeetCode495. 提莫攻击 | Teemo Attacking
In LOL world, there is a hero called Teemo and his attacking can make his enemy Ashe be in poisoned ...
- [Swift]LeetCode529. 扫雷游戏 | Minesweeper
Let's play the minesweeper game (Wikipedia, online game)! You are given a 2D char matrix representin ...
- 安装部署jumpserver3.0
1.安装依赖包yum -y install git readline-devel automake autoconf2.下载 jumpservergit clone https://github.co ...
- 必须知道的Java八大排序算法
冒泡排序.简单选择.直接插入.快速排序.堆排序.希尔排序.归并排序.基数排序. 将其按排序方式分类如下图所示: 1.冒泡排序: 基本思想——在要排序的一组数中,对当前还未排好序的范围内的全部数据,自上 ...