如何禁止在Windows Server 2008 R2的IIS 7.5中特定目录执行脚本?

avatar
作者
猴君
阅读量:0
在IIS7.5中,通过选择目录,打开功能视图,双击“处理程序映射”,在右侧操作栏点击“编辑功能权限”,取消勾选“脚本”,即可禁止执行脚本。

在Windows Server 2008 R2上使用IIS7.5禁止特定目录执行脚本的方法,可以通过创建或修改web.config文件来实现,以下是详细步骤和相关信息:

如何禁止在Windows Server 2008 R2的IIS 7.5中特定目录执行脚本?

方法

1、通过创建或编辑web.config文件:在需要禁止脚本执行的目录下创建一个web.config文件,并添加特定的配置代码来移除各种脚本处理程序。

2、直接在IIS管理控制台中操作:通过IIS管理控制台的功能视图,编辑特定目录的处理程序映射,取消脚本的执行权限。

详细步骤

通过web.config文件禁止脚本执行

1、访问目标目录:打开文件资源管理器,导航到您希望禁止脚本执行的目录。

2、创建或编辑web.config文件:在该目录下创建一个新的web.config文件,或者如果已经存在,则编辑现有的文件。

3、添加配置代码:在web.config文件中添加以下XML代码:

```xml

<?xml version="1.0" encoding="UTF-8"?>

<configuration>

<system.webServer>

<handlers>

<remove name="ASPClassic" />

<remove name="PHP-FastCGI" />

<remove name="ASPNET-ISAPI-1.1-AXD" />

<remove name="ASPNET-ISAPI-1.1-HttpRemotingHandlerFactory-rem" />

<remove name="ASPNET-ISAPI-1.1-HttpRemotingHandlerFactory-soap" />

<remove name="ASPNET-ISAPI-1.1-PageHandlerFactory" />

<remove name="ASPNET-ISAPI-1.1-SimpleHandlerFactory" />

<remove name="ASPNET-ISAPI-1.1-WebServiceHandlerFactory" />

<remove name="AssemblyResourceLoader-Integrated" />

<remove name="AXD-ISAPI-2.0" />

<remove name="AXD-ISAPI-2.0-64" />

<remove name="HttpRemotingHandlerFactory-rem-Integrated" />

<remove name="HttpRemotingHandlerFactory-rem-ISAPI-2.0" />

<remove name="HttpRemotingHandlerFactory-rem-ISAPI-2.0-64" />

<remove name="HttpRemotingHandlerFactory-soap-Integrated" />

<remove name="HttpRemotingHandlerFactory-soap-ISAPI-2.0" />

<remove name="HttpRemotingHandlerFactory-soap-ISAPI-2.0-64" />

<remove name="PageHandlerFactory-Integrated" />

<remove name="PageHandlerFactory-ISAPI-2.0" />

<remove name="PageHandlerFactory-ISAPI-2.0-64" />

<remove name="Perl-CGI" />

<remove name="Perl-ISAPI" />

<remove name="rules-64-ISAPI-2.0" />

<remove name="rules-Integrated" />

如何禁止在Windows Server 2008 R2的IIS 7.5中特定目录执行脚本?

<remove name="rules-ISAPI-2.0" />

<remove name="SecurityCertificate" />

<remove name="SimpleHandlerFactory-Integrated" />

<remove name="SimpleHandlerFactory-ISAPI-2.0" />

<remove name="SimpleHandlerFactory-ISAPI-2.0-64" />

<remove name="svc-Integrated" />

<remove name="svc-ISAPI-2.0" />

<remove name="svc-ISAPI-2.0-64" />

<remove name="TraceHandler-Integrated" />

<remove name="TRACEVerbHandler" />

<remove name="WebAdminHandler-Integrated" />

<remove name="WebServiceHandlerFactory-Integrated" />

<remove name="WebServiceHandlerFactory-ISAPI-2.0" />

<remove name="WebServiceHandlerFactory-ISAPI-2.0-64" />

<remove name="xoml-64-ISAPI-2.0" />

<remove name="xoml-Integrated" />

<remove name="xoml-ISAPI-2.0" />

</handlers>

</system.webServer>

</configuration>

```

4、保存文件:保存web.config文件后,该目录及其子目录将只有读取权限,而无法执行任何脚本。

5、恢复脚本执行权限:如果需要恢复脚本执行权限,只需删除该目录下的web.config文件即可。

通过IIS管理控制台操作

1、打开IIS管理控制台:点击“开始”菜单,选择“管理工具”,然后选择“Internet信息服务(IIS)管理器”。

2、选择目标网站和目录:在左侧的连接面板中,展开服务器节点,选择您要配置的网站,然后定位到要禁止脚本执行的目录。

3、编辑处理程序映射:在中间的“功能视图”面板中,双击“处理程序映射”。

4、取消脚本执行权限:在右侧的操作面板中,找到并点击“编辑功能权限”,在弹出的对话框中,取消勾选“脚本”选项。

5、确认更改:点击“确定”按钮以应用更改,这将在当前目录下生成一个web.config文件,完成设置。

相关问题与解答

1、Q1: 如何验证某个目录的脚本执行权限是否已被禁用?

A1: 您可以通过尝试在该目录中运行一个简单的脚本(如PHP或ASP文件)来验证,如果脚本未执行并返回错误信息,说明脚本执行权限已成功禁用,您还可以检查该目录下是否存在web.config文件,并查看其内容是否包含上述的配置代码。

2、Q2: 除了web.config文件外,还有哪些方法可以在IIS7.5中禁止目录执行脚本?

A2: 除了通过web.config文件外,您还可以使用IIS管理控制台的功能视图中的“处理程序映射”选项来禁止目录执行脚本,具体步骤包括选择目标目录,编辑处理程序映射,然后取消勾选“脚本”选项,这种方法同样会在当前目录下生成一个web.config文件来应用更改。

各位小伙伴们,我刚刚为大家分享了有关“Win2008 r2 IIS7.5制定目录禁止执行脚本的方法”的知识,希望对你们有所帮助。如果您还有其他相关问题需要解决,欢迎随时提出哦!

    广告一刻

    为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!