.Net4.0 Web.config 配置实践

2024-06-20 13:22:06 浏览数 (3)

目录

关于 Web.config

运行环境

配置实践

请求验证模式兼容旧版本

上传文件限制

Request.Path危险值配置

全站应用UTF-8编码

设置日期格式

每个会话的限制并发请求数

正常运行指定扩展名的文件

Json字符串超出最大长度限制

控件早期版本的呈现方式

C# 操作 Web.config

小结


关于 Web.config

当通过.NET 新建一个Web应用程序项目后,默认情况下会在根目录自动创建一个默认的Web.config文件,其是一个XML文本文件,内容包括运行应用默认的所有运行基础配置。

除根目录外,可以每个要特殊配置的子目录下新建一个Web.config文件。它可以在继承父目录的配置信息以外,可以自定义重写或修改父目录中定义的设置。

在应用运行时对 Web.config 文件的修改不需要重启服务就可以生效,因此请注意正确的修改内容,否则会引起应用站点异常并报错。

Web.config 文件可以自定义配置进行扩展,通过自定义配置参数,满足我们日常对应用程序的其它配置需求。

运行环境

操作系统: Windows Server 2019 DataCenter

.net版本: .netFramework4.0 或以上

编辑工具:VS2019 或其它任何文本编辑器

配置实践

请求验证模式兼容旧版本

请求验证模式定义了如何处理客户端请求中的输入内容的安全性,我们运行的是 .netFrameword 4.7.1 版本,为保证兼容性,最好配置

代码语言:javascript复制
<system.web>
 <httpRuntime  requestValidationMode="3.5"  />
</system.web>
上传文件限制

这是经常用到和遇到的一个问题,对于默认配置 maxRequestLength 一般仅允许上传不超过4Mb的文件,我们可以通过修改下列配置节:

代码语言:javascript复制
<system.web>

    <httpRuntime  maxRequestLength="20480000"  />

</system.web>

我们还可以配置些节点:

代码语言:javascript复制
<system.webServer>
    <security>
      <requestFiltering>
        <requestLimits maxAllowedContentLength="2147483647" />
      </requestFiltering>
    </security>
</system.webServer>

如果不起作用还可以配置如下节(如果存在):

代码语言:javascript复制
<aspnetUploadSettings>
    <add key="maxRequestLength" value="20480000" />
</aspnetUploadSettings>
Request.Path危险值配置

在页面处理输入时,我们会遇到客户端(&)中检测到有潜在危险的 Request.Path 值错误 (即包含一些被认为是危险的字符输入,如脚本标记等),如果我们有需要关闭此功能时,可以在应用页面头部加入如下配置:

代码语言:javascript复制
<%@ Page Language="C#"  ValidateRequest="FALSE"  %>

Web.config 文件里我们可以配置如下:

代码语言:javascript复制
<system.web>
    <httpRuntime requestPathInvalidCharacters="" />
</system.web>
全站应用UTF-8编码

目前utf-8编码是广泛应用的一种编码,我们可以默认配置如下节:

代码语言:javascript复制
<system.web>
    <globalization requestEncoding=”utf-8″ responseEncoding=”utf-8″ fileEncoding="utf-8" />
</system.web>

也可以单独为某页面配置编码,如下示例:

代码语言:javascript复制
<location path="cc/test.aspx">
    <system.web>
      <globalization requestEncoding="gb2312" responseEncoding="gb2312"  fileEncoding="gb2312"/>
    </system.web>
</location>
设置日期格式

某些情况我们需要对日期格式进行符合自己应用的标准化格式输出,如 2024-04-22的日期格式,我们会发现从数据库提取的日期格式未必如预期那样,即使配置了数据库格式及WINDOWS环境日期格式,仍然不能按照预期显示,那么我们可以尝试在 Web.config <appSettings>配置节添加如下key:

代码语言:javascript复制
<appSettings>
    <add key="ShortDatePattern" value="yyyy-MM-dd" />
</appSetttings>

请注意 yyyy-MM-dd 是区分大小写的。更多配置可以参考如下链接:

https://learn.microsoft.com/zh-cn/previous-versions/bb688124(v=msdn.10)?redirectedfrom=MSDN

我们发现有时配置了此节会有失效的情况,可以打开 Web.config 文件,随便改动一下,再保存一下理论上就能恢复正常的日期显示了。

每个会话的限制并发请求数

这是为了解决 .NET Framework 4.7、4.7.1 和 4.7.2 中引入的应用兼容性问题,可以在 Web.config <appSettings>配置节添加如下key:

代码语言:javascript复制
<appSettings>
    <add key="aspnet:RequestQueueLimitPerSession" value="2147483647"/>
</appSetttings>

更多详情请参考如下链接:

有关迁移到 .NET Framework 4.7.x 的操作的重定向目标更改

正常运行指定扩展名的文件

在我们运行的一些应用中,需要运行 mp4 文件,发现运行时出现错误,我们可以加入对该扩展名的支持,如下配置:

代码语言:javascript复制
<system.webServer>
   <staticContent>
      <remove fileExtension=".mp4" />
      <mimeMap fileExtension=".mp4" mimeType="video/mp4" />
   </staticContent>
</system.webServer>

请注意 remove 节,是一种比较稳妥和兼容的写法,否则可能未必能够达到您的预期。

Json字符串超出最大长度限制

在处理Json字符串序列化的时候,可能会遇到字符串超过长度限制的错误,我们可以配置如下节:

代码语言:javascript复制
<system.web.extensions>
    <scripting>
      <webServices>
        <jsonSerialization maxJsonLength="204800"/>
      </webServices>
    </scripting>
</system.web.extensions>
控件早期版本的呈现方式

指定控件应以 ASP.NET 的早期版本中的呈现方式,可以设置为3.5(最低版本),如下配置:

代码语言:javascript复制
<system.web>
    <pages controlRenderingCompatibilityVersion="3.5" clientIDMode="AutoID">
      <controls>
        <add tagPrefix="asp" namespace="System.Web.UI" assembly="System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" />
      </controls>
    </pages>
</system.web>

这是Pages的通用设置方法,更多信息请参考如下链接:

https://learn.microsoft.com/zh-cn/previous-versions/950xf363(v=vs.110)?redirectedfrom=MSDN

C# 操作 Web.config

appSettings节是我们经常自定义变量配置的节,在此我们分享 C# 一个appSettingsEdit方法,可以动态的配置指定的变量及值,其参数见下表:

序号

参数名

类型

说明

1

WebConfigDirectory

string

Web.config文件所在的目录(不包含文件名)

2

appSettingsAddkey

string

要在 appSettings 节中添加的键值 Key 名称

3

keyvalue

string

要在 appSettings 节中添加的键值 Key 的值 Value

方法代码如下:

代码语言:javascript复制
public bool appSettingsEdit(string WebConfigDirectory,string appSettingsAddkey,string keyvalue) 
		{ 
            
			try 
			{ 
				string path=WebConfigDirectory "\web.config"; 
				XmlDocument xd=new XmlDocument(); 
				xd.Load(path); 

				//如果没有appSetting,则添加 
				if(xd.SelectNodes("//appSettings").Count==0) 
				{ 
					xd.DocumentElement.AppendChild(xd.CreateElement("appSettings")); 
				} 

				//判断节点是否存在,如果存在则修改当前节点 
				bool addNode=true; 
				foreach(XmlNode xn1 in xd.SelectNodes("/configuration/appSettings/add")) 
				{ 
					if(xn1.Attributes["key"].Value==appSettingsAddkey) 
					{ 
						addNode=false; 
						xn1.Attributes["value"].Value=keyvalue; 
						// xn1.ParentNode.RemoveChild(xn1); 
						break; 
					} 
				} 

				//当前节点不存在,则添加新节点 
				if(addNode) 
				{ 
					//创建新节点 
					XmlNode xn2=xd.CreateElement("add"); 

					//添加key 
					XmlAttribute xa=xd.CreateAttribute("key"); 
					xa.Value=appSettingsAddkey; 
					xn2.Attributes.Append(xa); 

					//添加value 
					xa=xd.CreateAttribute("value"); 
					xa.Value=keyvalue; 
					xn2.Attributes.Append(xa); 
					xd.SelectSingleNode("/configuration/appSettings").AppendChild(xn2); 
				} 
				//保存web.config 
				xd.Save(path); 
				return true; 
			} 
			catch 
			{ 
				return false; 
			} 
} 

小结

一般情况下请勿更改 Web.config 的文件名及扩展名,因为 .config 文件扩展名可防止 ASP.NET 下载相应文件。

更高级的父对象继承可以更改 %SystemRoot%Microsoft.NETFramework<版本>CONFIG 目录下的 Machine.config 和 Web.config 文件继承所有基础配置设置,此文件属于服务器配置级别,要高于单独的应用程序级别。

到此关于 Web.config 的配置我们就讲到这里,后续随着实际的应用我们会继续丰富本文章内容,感谢您的阅读,希望本文对您能有所帮助。

0 人点赞