易丰科技

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 3440|回复: 0
打印 上一主题 下一主题

如何保护纯 htm | html 网页

[复制链接]

111

主题

117

帖子

3588

积分

论坛元老

Rank: 8Rank: 8

积分
3588
跳转到指定楼层
楼主
发表于 2013-4-18 03:21:27 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
如何保护纯 htm | html 网页

经测试,在 IIS 网站下的 htm | html 会直接输出,不会受到 asp.net 的管控
也因此在 asp.net 网站下的 Global.asax 之中的事件
比如 Session_OnStart 并不会被执行。

解决方法:
在 web.config 裹,输入如下:
    <compilation debug="true" targetFramework="4.0">
      <buildProviders>
        <add extension=".html" type="System.Web.Compilation.PageBuildProvider" />
        <add extension=".htm" type="System.Web.Compilation.PageBuildProvider" />
      </buildProviders>
    </compilation>

  <system.webServer>
    <modules runAllManagedModulesForAllRequests="true"/>
    <handlers>
      <add name="HTML" path="*.html" verb="GET, HEAD, POST, DEBUG"   type="System.Web.UI.PageHandlerFactory" resourceType="Unspecified" requireAccess="Script" />
      <add name="HTM" path="*.htm" verb="GET, HEAD, POST, DEBUG" type="System.Web.UI.PageHandlerFactory" resourceType="Unspecified" requireAccess="Script" />
    </handlers>
  </system.webServer>

这些设定就可以让 htm | html 的 request 透过 ASP.NET 来处理
所以,要进行登入验证的话,如果有整合 membership 则可以:
    <authentication mode="Forms">
      <forms loginUrl="~/Account/Login.aspx" timeout="2880"/>
    </authentication>
    <authorization>
      <deny users="?" />
    </authorization>

如果不整合 membership provider
则可以如下
    void Session_Start(object sender, EventArgs e)
    {
        //System.Diagnostics.Debug.WriteLine("Session Start");
        if (Session["username"] == null)
            Response.Redirect("MyLogin.aspx");
    }
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|易丰科技

GMT+8, 2024-5-19 08:28 , Processed in 0.021741 second(s), 20 queries .

Powered by Discuz! X3

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表