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数组在方 ...
随机推荐
- 1 eclipse 离线安装activiti插件
第一步:下载需要的离线activiti文件: 链接:https://pan.baidu.com/s/1-_XjIsuZfhiEZn6iLul6-Q 密码:mfyk (这是其他网友的链接) 第二步: ...
- 权限系统设计-day02
练习中的问题: 1,<s:url action="employee_input" />这个标签用来让struts自动生成请求的路径,struts生成的路径是一个全路径, ...
- python 外键用法 多对多关系 ORM操作 模板相关
一.app/models中写类(设计表结构) 1.普通类 class A(models.Model): id=modles.AutoField(primary_key=True) name=mode ...
- victory-native的使用
Victory用于构建交互数据可视化的可组合React组件的生态系统 想写又不想写,真尴尬...
- Android 音视频开发(三):使用 AudioTrack 播放PCM音频
一.AudioTrack 基本使用 AudioTrack 类可以完成Android平台上音频数据的输出任务.AudioTrack有两种数据加载模式(MODE_STREAM和MODE_STATIC),对 ...
- [Swift]LeetCode11. 盛最多水的容器 | Container With Most Water
Given n non-negative integers a1, a2, ..., an , where each represents a point at coordinate (i, ai). ...
- [Swift]LeetCode31. 下一个排列 | Next Permutation
Implement next permutation, which rearranges numbers into the lexicographically next greater permuta ...
- [Swift]LeetCode209. 长度最小的子数组 | Minimum Size Subarray Sum
Given an array of n positive integers and a positive integer s, find the minimal length of a contigu ...
- [Swift]LeetCode274.H指数 | H-Index
Given an array of citations (each citation is a non-negative integer) of a researcher, write a funct ...
- [Swift]LeetCode498. 对角线遍历 | Diagonal Traverse
Given a matrix of M x N elements (M rows, N columns), return all elements of the matrix in diagonal ...