web.config小技巧

简介:
一、应用身份验证、但个别目录或文件不需要身份验证
 最常见的是一个网站的后台需要验证,而前台是不需要的;一般登录页面会有验证码、而生成验证码那个页面是不需要验证的、否则验证图片是显示不出来的。
解决方法:
None.gif < system .web >
None.gif      
<!--  身份验证  -->
None.gif      
< authentication  mode ="Forms" >
None.gif        
< forms  name =".myForm"  loginUrl ="login.aspx"  timeout ="20"  protection  ="All" />
None.gif      
</ authentication >
None.gif      
< authorization  >
None.gif        
< deny  users  ="?" />
None.gif      
</ authorization >
None.gif    
</ system.web >
None.gif  
<!--  验证码  -->
None.gif  
< location  path  ="CheckCode.aspx" >
None.gif    
< system .web  >
None.gif      
< authorization  >
None.gif        
< allow  users  ="*" />
None.gif      
</ authorization >
None.gif    
</ system.web >
None.gif  
</ location >
使用身份验证、禁止匿名用户访问,同时对页面checkcode.aspx允许所有用户访问、即不用验证。

二、改写(不需求)web.config继承
假设IIS中有个站点A、而A站点下面有个虚拟目录B、此时可以输入:" ttp://ip 址/"  访问到A站点,输入 http://ip地址/B 访问到B网站;而B项目中的web.config首先会继承A站点的web.config,如果A的config有很多设置如<httpModules>,<page>等,而B项目的config没有这些设置,项目也没用到这些设置,但B的程序在运行时确会出错、原因就是它继承A的config;这个让人有点讨厌“我压根没用它、怎么会有错?且提示出错的那个文件是A的config”,可以这样解决:
A项目用到了主题
None.gif < pages  enableEventValidation ="false"  validateRequest ="false"  theme ="default" >
B项目不用
None.gif < pages  enableEventValidation ="false"  validateRequest ="false"  theme ="" >
让B的主题为空、否则B运行时提示找不到default主题目;

A的设置
None.gif   < httpModules >
None.gif          
< add  name ="SiteCache"  type ="SiteCache" />
None.gif        
</ httpModules >
B的设置(不用的项,清除)
None.gif   < httpModules >
None.gif     
< clear />
None.gif 
</ httpModules >
如果A.B都用到
None.gif < appSettings >
None.gif  
< add  key ="app"  value ="dot.gif"   />
None.gif
</ appSettings >
B运行时会提示app已经加载,此时可以
None.gif < appSettings >
None.gif  
< remove  name ="app"   />
None.gif  
< add  key ="app"  value =""   />
None.gif
</ appSettings >
或者:
None.gif < appSettings >
None.gif  
< clear  />
None.gif  
< add  key ="app"  value =""   />
None.gif
</ appSettings >

三、禁止web.config重写
同上面的例子、如果B中的config设置必须与A中的相同,不能重写,则A的config设置
None.gif      < location  path ="B"  allowOverride ="false" >
None.gif      
< system .web >
None.gif        
< httpModules >
None.gif          
< add  name ="SiteCache"  type ="SiteCache" />
None.gif        
</ httpModules >
None.gif      
</ system.web >
None.gif  
</ location >
此时B的config中<httpModules>设置不能改写,须和A的设置相同。
本文转自chy710博客园博客,原文链接:http://www.cnblogs.com/chy710/archive/2007/02/11/647537.html ,如需转载请自行联系原作者
相关文章
|
JavaScript
webpack4 一些常用配置
webpack4 一些常用配置
webpack4 一些常用配置
|
JavaScript 前端开发 开发者
webpack 配置文件的使用| 学习笔记
快速学习 webpack 配置文件的使用
75 0
|
JavaScript 前端开发
webpack手动配置
webpack版本: 4.29.6babel版本: 7.4.0 webpack 安装 运行 npm i webpack-cli webpack --save-dev, 安装到项目开发依赖 webpack 配置文件 在项目根目录中创建 webpack.
1111 0
|
Web App开发 Windows
|
安全 .NET 开发框架
|
Web App开发 XML .NET