第十八节:跨域请求的解决方案和WebApi特有的处理方式

一. 简介

前言: 跨域问题发生在Javascript发起Ajax调用,其根本原因是因为浏览器对于这种请求,所给予的权限是较低的,通常只允许调用本域中的资源, 除非目标服务器明确地告知它允许跨域调用。假设我们页面或者应用已在 http://www.test1.com 上了,而我们打算从 http://www.test2.com 请求提取数据。 一般情况下,如果我们直接使用 Ajax 来请求将会失败,浏览器也会返回“源不匹配”的错误,"跨域"也就以此由来。 

  本节将结合MVC和WebApi两套框架介绍通用的跨域请求的解决方案、WebApi特有的解决方案、几种JSONP模式、以及如何让WebApi也支持JSONP的改造方案。

  下面列举几种跨域的情况:

 

二.  Mvc和WebApi通用的模式

  该模式是MVC和WebApi通用的一种处理模式,简单便捷,不需要额外添加多余的程序集,只需要在WebConfig中进行配置一下即可。

  同时缺点也比较明显,那就是只能全局配置,配置完后,所有的控制器下的方法都支持跨域了。

1. 代码配置如下,在 <system.webServer></system.webServer>节点的 最顶 添加如下代码:

PS:分析下面代码

  A. Access-Control-Allow-Origin :代表请求地址,如:" http://localhost:2131, http://localhost:2133" 多个地址之间用逗号隔开,*  代表运行所有

  B. Access-Control-Allow-headers: 代表表头

  C. Access-Control-Allow-method: 代表请求方法。如:"GET,PUT,POST,DELETE"

复制代码

  <system.webServer><!--允许跨域请求的配置  WebApi和MVC通用--><httpProtocol><customHeaders><add name="Access-Control-Allow-Origin" value="*" /><add name="Access-Control-Allow-Headers" value="Access-Control-Allow-Origin, AppKey, Authorization" /><add name="Access-Control-Allow-Methods" value="GET, POST, OPTIONS" /><add name="Access-Control-Request-Methods" value="GET, POST, OPTIONS" /></customHeaders></httpProtocol><!--允许跨域请求的配置  WebApi和MVC通用   至此结束--><modules><remove name="TelemetryCorrelationHttpModule" /><add name="TelemetryCorrelationHttpModule" type="Microsoft.AspNet.TelemetryCorrelation.TelemetryCorrelationHttpModule, Microsoft.AspNet.TelemetryCorrelation" preCondition="integratedMode,managedHandler" /><remove name="ApplicationInsightsWebTracking" /><add name="ApplicationInsightsWebTracking" type="Microsoft.ApplicationInsights.Web.ApplicationInsightsHttpModule, Microsoft.AI.Web" preCondition="managedHandler" /></modules><validation validateIntegratedModeConfiguration="false" /><handlers><remove name="ExtensionlessUrlHandler-Integrated-4.0" /><remove name="OPTIONSVerbHandler" /><remove name="TRACEVerbHandler" /><add name="ExtensionlessUrlHandler-Integrated-4.0" path="*." verb="*" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" /></handlers></system.webServer>

复制代码

2.  分别在MVC和WebApi下的FifthController和CorsController中新建GetUserName方法,代码如下:

复制代码

 1         /// <summary>2         /// 方案一的测试接口3         /// http://localhost:2131/api/Fifth/GetUserName?userName=admin4         /// </summary>5         /// <param name="userName"></param>6         /// <returns></returns>7         [HttpGet]8         public string GetUserName(string userName)9         {
10             return $"WebApi:userName的值为{userName}";
11         }    
12         /// <summary>
13         /// 方案一的测试接口
14         /// http://localhost:1912/CorsTest/GetUserName
15         /// </summary>
16         /// <param name="userName"></param>
17         /// <returns></returns>
18         [HttpGet]
19         public string GetUserName(string userName)
20         {
21             return $"MVC:userName的值为{userName}";
22         }    

复制代码

3. 在一个新项目中进行跨域调用:

复制代码

1   //1. WebApi
2  $.get("http://localhost:2131/api/Fifth/GetUserName", { userName: "admin" }, function (data) {
3      console.log(data);
4  });
5  //2. MVC
6   $.get("http://localhost:1912/CorsTest/GetUserName", { userName: "admin" }, function (data) {
7      console.log(data);
8  });

复制代码

注释掉webconfig中的代码配置结果如下:

配置后的结果如下:

 

三. WebApi特有的处理方式

  该模式和上述通用的模式相比较, 最大的好处就是比较灵活,既可以作用于全局,也可以特性的形式作用于Controller,或者直接作用于Action。

  该方案的前提:先通过Nuget添加【Microsoft.AspNet.WebApi.Cors】程序集。

  核心方法:EnableCorsAttribute(string origins, string headers, string methods)

  * 代表允许所有。

  A.origins代表请求地址:" http://localhost:2131, http://localhost:2133" 多个地址之间用逗号隔开

  B.headers代表表头:

  C.method代表请求方法:"GET,PUT,POST,DELETE"

1. 作用于全局

  在WebApiConfig类中的Register方法中添加:config.EnableCors(new EnableCorsAttribute("*", "*", "*"));

2. 作用于Controller

  (1). 在WebApiConfig类中的Register方法中添加:config.EnableCors();

  (2). 在FifthController控制器上添加特性:[EnableCors("*", "*", "*")]

3. 作用于Action

  (1). 在WebApiConfig类中的Register方法中添加:config.EnableCors();

  (2). 在GetUserName2方法上添加特性:[EnableCors("*", "*", "*")]

部分代码如下图:

代码测试:分别进行上面1,2,3的代码配置,测试三次,结果如下,均实现了跨域。

1   $.get("http://localhost:2131/api/Fifth/GetUserName2", { userName: "admin" }, function (data) {
2      console.log(data);
3   });

结果:

 

 

四. MVC下JSONP的几种写法

 1. JSON和JSONP的区别

① json格式:
 {
  "id":123,
  "name":"ypf"
 }
② jsonp格式:在json外面包了一层
callback({
  "id":123,
  "name":"ypf"
 })
其中callback取决于url传到后台是什么,他就叫什么

2. 利用Jquery实现JSONP

注意前端的两个参数: dataType: "jsonp", jsonp: "myCallBack", 其中myCallBack需要和服务端回掉方法中的参数名相对应,注释掉这句话默认传的名称叫callback

后台要有一个参数来接受这个包裹的名称,然后用它把最后的返回值包裹起来以string的形式返回给客户端,注:数据要进行序列化。

这种方式有个明显缺点:假设有一天这个接口不需要跨域,要改会普通请求的普通返回形式, 则需要改代码,就哭了,而且每个接口都要这么对应去写跨域的写法,侵入性太强。

服务器端代码分享:

复制代码

 1        /// <summary>2         /// 方案三:MVC默认支持JSONP3         /// 但需要服务器端有类似callback参数接受的,然后对返回值进行拼接4         /// </summary>5         /// <param name="callBack"></param>6         /// <param name="userName"></param>7         /// <returns></returns>8         [HttpGet]9         public dynamic GetInfor(string myCallBack, string userName)
10         {
11             var data = new
12             {
13                 id = userName + "001",
14                 userName = userName
15             };
16             JavaScriptSerializer js = new JavaScriptSerializer();
17             string xjs = js.Serialize(data);
18             return Content($"{myCallBack}({xjs})");
19 
20             //或者直接返回字符串
21             //return $"{myCallBack}({xjs})";
22         }

复制代码

JS调用代码分享:

复制代码

 1          $.ajax({2                     url: 'http://localhost:1912/CorsTest/GetInfor',3                     type: "get",4                     dataType: "jsonp",5                     //需要和服务端回掉方法中的参数名相对应6                     //注释掉这句话默认传的名称叫callback7                     jsonp: "myCallBack",   8                     cache: false,9                     data: { userName: "ypf" },
10                     success: function (data) {
11                         console.log(data);
12                         console.log(data.id);
13                         console.log(data.userName);
14                     }
15                 });

复制代码

结果:

3. 思考:MVC下能否也面向切面的形式实现跨域?

效果:①方法依然常规写法不需要特意的用跨域的写法 ②哪个方法想支持跨域,哪个方法不想支持能灵活的控制,不要去改方法内部的代码。③跨域调用和非跨域调用都能调用

思路1:利用过滤器以特性的形式进行作用,同时过滤器内实现方案一中的代码,详见MvcCors过滤器和GetInfor2方法

过滤器代码

复制代码

 1  public class MvcCors:ActionFilterAttribute2     {3         /// <summary>4         /// 方法执行后执行5         /// </summary>6         /// <param name="filterContext"></param>7         public override void OnActionExecuted(ActionExecutedContext filterContext)8         {9             HttpContext.Current.Response.Headers.Add("Access-Control-Allow-Origin", "*");
10             HttpContext.Current.Response.Headers.Add("Access-Control-Allow-Headers", "x-requested-with,content-type,requesttype,Token");
11             HttpContext.Current.Response.Headers.Add("Access-Control-Allow-Methods", "POST,GET");
12         }
13     }

复制代码

GetInfor2方法

复制代码

 1       /// <summary>2         /// 方案三:自己利用方案一中的原理进行改造3         /// 让方法灵活的支持跨域4         /// </summary>5         /// <param name="userName"></param>6         /// <returns></returns>7         [MvcCors]8         [HttpGet]9         public string GetInfor2(string userName)
10         {
11             return $"MVC:userName的值为{userName}";
12         }

复制代码

JS代码

1   $.get("http://localhost:1912/CorsTest/GetInfor2", { userName: "admin" }, function (data) {
2      console.log(data);
3   });

调用结果

 

思路2:利用过滤器以特性的形式进行作用,同时过滤器中进行判断该调用是否属于跨域,属于的话就对返回值进行跨域的包裹返回,不属于的话,原样返回。(MVC版暂未实现,WebApi版详见下面)

继续思考:重写ContentResult,在重写里面判断,如果属于跨域请求,返回值进行跨域的返回,如果不是跨域请求,正常返回 (暂未实现)

 

五. WebApi下JSONP的改造

前言:WebApi默认不支持JSONP, 这里我们需要对其进行改造

测试不支持的代码

复制代码

 1  /// <summary>2         /// 原始的JSONP模式,返现不支持3         /// </summary>4         /// <param name="callBack"></param>5         /// <param name="userName"></param>6         /// <returns></returns>7         [HttpGet]8 9         public dynamic GetInfor(string myCallBack, string userName)
10         {
11             var data = new
12             {
13                 id = userName + "001",
14                 userName = userName
15             };
16             JavaScriptSerializer js = new JavaScriptSerializer();
17             string xjs = js.Serialize(data);
18 
19             return $"{myCallBack}({xjs})";
20         }

复制代码

复制代码

 1           $.ajax({2                     url: 'http://localhost:1912/CorsTest/GetInfor3',3                     type: "get",4                     dataType: "jsonp",5                     //需要和服务端回掉方法中的参数名相对应6                     //注释掉这句话默认传的名称叫callback7                     jsonp: "myCallBack",8                     cache: false,9                     data: { userName: "ypf" },
10                     success: function (data) {
11                         console.log(data);
12                         console.log(data.id);
13                         console.log(data.userName);
14                     }
15                 });

复制代码

改造一:

a. 通过Nuget安装程序集:WebApiContrib.Formatting.Jsonp.

b. 在Global文件中进行配置

//允许JSON的配置(注意前端传过来的名字必须要为myCallBack)

GlobalConfiguration.Configuration.AddJsonpFormatter(GlobalConfiguration.Configuration.Formatters.JsonForma‌​tter, "myCallBack");

服务器端代码:

复制代码

 1         /// <summary>2         /// 方案四:利用WebApiContrib.Formatting.Jsonp程序集改造支持跨域3         /// </summary>4         /// <param name="callBack"></param>5         /// <param name="userName"></param>6         /// <returns></returns>7         [HttpGet]8 9         public dynamic GetInfor2(string userName)
10         {
11             var data = new
12             {
13                 id = userName + "001",
14                 userName = userName
15             };
16             JavaScriptSerializer js = new JavaScriptSerializer();
17             string xjs = js.Serialize(data);
18             return $"{xjs}";
19         }

复制代码

前端JS代码:

复制代码

         $.ajax({url: 'http://localhost:2131/api/Fifth/GetInfor2',type: "get",dataType: "jsonp",//需要和服务端回掉方法中的参数名相对应//注释掉这句话默认传的名称叫callbackjsonp: "myCallBack",cache: false,data: { userName: "ypf" },success: function (data) {console.log(data);var jdata = JSON.parse(data);console.log(jdata.id);console.log(jdata.userName);}});    

复制代码

测试结果: 

改造二:

  利用上述MVC中的思路:利用过滤器以特性的形式进行作用,同时过滤器中进行判断该调用是否属于跨域,属于的话就对返回值进行跨域的包裹返回,不属于的话,原样返回。

过滤器代码:

复制代码

 1  public class JsonCallbackAttribute:ActionFilterAttribute2     {3         private const string CallbackQueryParameter = "myCallBack";4         public override void OnActionExecuted(HttpActionExecutedContext context)5         {6             var callback = string.Empty;7             if (IsJsonp(out callback))8             {9                 var jsonBuilder = new StringBuilder(callback);
10                 //将数据包裹jsonp的形式进行返回
11                 jsonBuilder.AppendFormat("({0})", context.Response.Content.ReadAsStringAsync().Result);
12                 context.Response.Content = new StringContent(jsonBuilder.ToString());
13             }
14 
15             base.OnActionExecuted(context);
16         }
17 
18         private bool IsJsonp(out string callback)
19         {
20             callback = HttpContext.Current.Request.QueryString[CallbackQueryParameter];
21             return !string.IsNullOrEmpty(callback);
22         }
23     }

复制代码

服务端代码:

复制代码

 1         /// <summary>2         /// 方案四(改造二):利用过滤器以特性的形式进行作用,同时过滤器中进行判断该调用是否属于跨域,3         /// 属于的话就对返回值进行跨域的包裹返回,不属于的话,原样返回。4         /// </summary>5         /// <param name="callBack"></param>6         /// <param name="userName"></param>7         /// <returns></returns>8         [HttpGet]9         [JsonCallback]
10 
11         public dynamic GetInfor3(string userName)
12         {
13             var data = new
14             {
15                 id = userName + "001",
16                 userName = userName
17             };
18             JavaScriptSerializer js = new JavaScriptSerializer();
19             string xjs = js.Serialize(data);
20             return $"{xjs}";
21         }

复制代码

js调用代码:

复制代码

 1           $.ajax({2                     url: 'http://localhost:2131/api/Fifth/GetInfor3',3                     type: "get",4                     dataType: "jsonp",5                     //需要和服务端回掉方法中的参数名相对应6                     //注释掉这句话默认传的名称叫callback7                     jsonp: "myCallBack",8                     cache: false,9                     data: { userName: "ypf" },
10                     success: function (data) {
11                         console.log(data);
12                         var jdata = JSON.parse(data);
13                         console.log(jdata.id);
14                         console.log(jdata.userName);
15                     }
16                 });

复制代码

结果返回:

 

六. 其它

  webSocket 和signalr也是一种跨域方式,mvc下可以利用script标签实现跨域。 

分享MVC下利用Script标签实现跨域

服务器端代码

复制代码

 1         // <summary>2         /// 扩展:3         /// 利用script标签实现JSONP的跨域4         /// 但需要服务器端有类似callback参数接受的,然后对返回值进行拼接5         /// </summary>6         /// <param name="callBack"></param>7         /// <param name="userName"></param>8         /// <returns></returns>9         public ActionResult GetInfor4(string callBack, string userName)
10         {
11             var data = new
12             {
13                 id = userName + "001",
14                 userName = userName
15             };
16             JavaScriptSerializer js = new JavaScriptSerializer();
17             string xjs = js.Serialize(data);
18             return Content($"{callBack}({xjs})");
19 
20             //或者直接返回字符串
21             //return $"{callback}({xjs})";
22         }

复制代码

前端js代码

复制代码

 1  //1. 原始写法2   $('<script/>').attr('src', 'http://localhost:1912/CorsTest/GetInfor4?callBack=myCallBack&userName=ypf').appendTo("body")3   //2. 封装写法4   CrossData('http://localhost:1912/CorsTest/GetInfor4', { userName: "ypf" }, 'myCallBack');5 6 7      //回调方法8         function myCallBack(data) {9             console.log(data);
10             console.log(data.id);
11             console.log(data.userName);
12         }
13         //封装跨域方法
14         function CrossData(url, data, callBackMethord) {
15             var queryStr = '?';
16             for (var key in data) {
17                 queryStr += key + '=' + data[key] + '&'
18             }
19             var newUrl = url + queryStr + 'callBack=' + callBackMethord;
20             $('<script/>').attr('src', newUrl).appendTo("body");
21         }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/438539.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

bit类型在oracle,奇怪的Oracle bitand函数

最近在用Oracle的bitand函数是遇到了一个奇怪的现象&#xff1a;declaren number default374123538;val number;begindbms_output.enable;val : bitand(n,16777215);dbms_output.put_line(val);end;/结果正确&#xff1a;5024786PL/SQL procedure successfully completed然后修…

ORM系列之Entity FrameWork详解

一. 谈情怀 从第一次接触开发到现在&#xff08;2018年&#xff09;&#xff0c;大约有六年时间了&#xff0c;最初阶段连接数据库&#xff0c;使用的是【SQL语句ADO.NET】&#xff0c;那时候&#xff0c;什么存储过程、什么事务 统统不理解&#xff0c;生硬的将SQL语句传入SQL…

oracle行转列 case,Oracle 行转列总结 Case When,Decode,PIVOT 三种方式

Decode 方式 SELECT a.COUNTRY AS "国家", SUM(DECODE(a.SEX, 1, a.POPULCATION)) AS "男", SUM(DECODE(a.SEX, 2, a.POPULCATION)) AS "女" FROM populations a GROUP BY a.COUNTRY -------------------------------------- Case When 方式 SEL…

第二节: 比较EF的Lambda查询和Linq查询写法的区别

简介 在前面EF的介绍中&#xff0c;曾多次提到过EF可以使用Lambda和Linq来完成对数据库的访问&#xff0c;这两种的语法的具体使用和注意事项在前面的DotNet进阶的系列章节中已经详细介绍过了&#xff0c;本次借着EF章节&#xff0c;重新调整了一下里面的规范和注意事项。 1. …

oracle 9i 只读模式,我的oracle 9i学习日志(6)--Starting Up and shutting down a Database

Starting Up a Database1、NOMOUNT这个状态下oracle server完成下列任务&#xff1a;a.读取初始化参数文件&#xff1b;b.为SGA分配内存&#xff1b;c.启动后台进程&#xff1b;d.打开alertSID.log文件和跟踪文件数据库必须被命名&#xff0c;即初始化文件或在startup命令里指定…

第三节: EF调用普通SQL语句的两类封装(ExecuteSqlCommand和SqlQuery )

一. 前言 在前面的两个章节中&#xff0c;我们分别详细介绍了EF的增删改的两种方式&#xff08;方法和状态&#xff09;和EF查询的两种方式( Lambda和Linq )&#xff0c;进行到这里&#xff0c;可以说对于EF&#xff0c;已经入门了&#xff0c;本来应该继续往下进行EF的高级属性…

连续反应matlab,MATLAB和Monte Carlo法在连续反应动力学中的应用.pdf

第42卷第4期 广 州 化 工 Vo1&#xff0e;42No&#xff0e;42014年 2月 GuangzhouChemicalIndustry Feb&#xff0e;2014MATLAB和 MonteCarlo法在连续反应动力学中的应用李 旭 &#xff0c;陈志刚(1湘南学院化学与生命科学系&#xff0c;湖南 郴州 423043&#xff1b;2中南大学…

第四节: EF调用存储过程的通用写法和DBFirst模式子类调用的特有写法

一. 背景 上一个章节&#xff0c;介绍了EF调用两类SQL语句&#xff0c;主要是借助 ExecuteSqlCommand 和 SqlQuery 两个方法来完成&#xff0c;在本章节主要是复习几类存储过程的写法和对应的EF调用这几类存储过程的写法&#xff0c;另外介绍EF的DBFirst模式的下EF存储过程的特…

oracle cogs 科目,请问R12中,Mtl_material_transaction中的 COGS Recognition记录是干啥的?

我今天抓取库存移动记录,发现Mtl_material_Transaction表中,在作完了sales Order 的ship confirm动作后产生了两笔库存移动记录,第一笔是Sales Issue的出库,quantity为负数,还有另外一笔,transaction type是 COGS Recognition,数量和SalesIssue的数量相等,但是为正数, 在Form界…

第五节: EF高级属性(一) 之 本地缓存、立即加载、延迟加载(不含导航属性)

一. 本地缓存 从这个章节开始&#xff0c;介绍一下EF的一些高级特性&#xff0c;这里介绍的首先介绍的EF的本地缓存&#xff0c;在前面的“EF增删改”章节中介绍过该特性&#xff08;SaveChanges一次性会作用于本地缓存中所有的状态的变化&#xff09;&#xff0c;在这里介绍一…

oracle卸数什么是ctrl文件,Oracle数据库的安装和卸载之道

成功安装数据库1、如果安装数据库时有两个文件&#xff0c;需要将两个文件合并后再安装将两个文件都解压后&#xff0c;1of2包含安装文件&#xff0c;2of2只包含jar包&#xff0c;需要将2of2中stage\Components下的文件夹复制到1of2的该目录下注&#xff1a;如果无此处操作&…

第六节: EF高级属性(二) 之延迟加载、立即加载、显示加载(含导航属性)

一. 简介 上一个章节中&#xff0c;也介绍了立即加载和延迟加载&#xff0c;但上一个章节是针对单表而言的&#xff0c;不含外键&#xff0c;立即也好&#xff0c;延迟也好&#xff0c;都是指单表中的数据。但本章节重点介绍的三种加载方式均是针对含&#xff08;导航属性、外键…

oracle adf 自定义lov,Oracle ADF table列自定义过滤组件的方法

shortDesc"#{bindings.Pay0detailVO1.hints.Vsource.tooltip}" id"soc41"contentStyle"width:100px;" value"#{vs.filterCriteria.Vsource}">正常拖拽过来的af:table组件的过滤行的查询区域只是文本输入域.如图:, 但是如果设计要求…

asp.net连oracle数据库,ASP.NET连接Oracle数据库的步骤详解(转)

在用ASP.NET开发应用程序时&#xff0c;我们会用到数据库。ASP.NET与Oracle的连接也是比较常用的。本文主要介绍了ASP.NET连接Oracle数据库的方法和步骤。ASP.NET连接Oracle数据库步骤如下&#xff1a;(1)安装oracle客户端工具。(2)打开 安装目录D:\oracle\product\10.2.0\clie…

第七节: EF的三种事务的应用场景和各自注意的问题(SaveChanges、DBContextTransaction、TransactionScope)

一. 什么是事务 我们通俗的理解事务就是一系列操作要么全部成功、要么全部失败(不可能存在部分成功&#xff0c;部分失败的情况)。 举一个事务在我们日常生活中的经典例子&#xff1a;两张银行卡(甲、乙)&#xff0c;甲向乙转钱&#xff0c;整个过程需要执行两个操作&#xff0…

linux怎么检测文件完整性,Linux如何基于AIDE检测文件系统完整性

一、AIDEAIDE(Advanced Intrusion Detection Environment)是一款针对文件和目录进行完整性对比检查的程序&#xff0c;它被开发成Tripwire的一个替代品。AIDE如何工作AIDE通过构造指定文件的完整性样本库(快照)&#xff0c;作为比对标准&#xff0c;当这些文件发生改动时&#…

第八节: EF的性能篇(一) 之 EF自有方法的性能测试

一. 开发中常见的性能问题 我们在日常开发过程中&#xff0c;由于一些不好的习惯&#xff0c;经常会导致所写的代码性能低下&#xff0c;却毫无发觉&#xff0c;下面就总结一下常见的一些性能问题。 1. 真假分页 ① 假分页&#xff1a; db.xxx.toList().Skip(2).take(4) 。 ②…

linux 中将文件设置密码,linux – 如何使用公钥在openssl中加密大文件

如何使用公钥加密大文件&#xff0c;以便没有人除了拥有私钥的人能够解密&#xff1f;我可以使RSA公钥和私钥&#xff0c;但当涉及到使用此命令加密大文件&#xff1a;openssl rsautl -encrypt -pubin -inkey public.pem -in myLargeFile.xml -out myLargeFile_encrypted.xml和…

如何查看自己linux版本,如何查看Linux操作系统版本?

1. 查看内核版本命令$ cat /proc/versionLinux version 2.6.32-358.el6.x86_64 (mockbuildc6b8.bsys.dev.centos.org) (gcc version 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC) ) #1 SMP Fri Feb 22 00:31:26 UTC 2013$ uname -aLinux 192.168.1.10 2.6.32-358.el6.x86_64 #1 SMP…

第九节: EF的性能篇(二) 之 Z.EntityFramework.Extensions程序集解决EF的性能问题

一. 综述 该模块主要介绍&#xff1a;EF的性能优化插件Z.EntityFramework.Extensions&#xff0c;该插件收费。 (一). 简介 1. 相关网站&#xff1a;http://www.zzzprojects.com/ 2. 下载途径&#xff1a;通过Nuget直接下载或者去官网下载(要注意更新最新版本&#xff0c;可…