表单身份验证在发布后不起作用

发布于 2024-12-28 11:27:59 字数 1731 浏览 1 评论 0原文

我一直在开发一个网站项目,该项目限制匿名用户访问某个文件夹,并允许登录的用户访问该文件夹。 这在我的开发机器上运行得很好。

然而,自从发布网站并部署到 Web 服务器(Windows Server 2008、IIS7)以来,表单身份验证似乎不起作用。匿名用户可以访问“受限”文件夹。 我比较了开发机器和Web服务器上的webconfig,它们是完全相同的。

我使用 .NET Framework 中内置的网站管理工具设置了对开发计算机上目录的访问/限制,使用此 教程。但是我知道这个工具只是本地主机?

请注意:我没有使用 asp.net 登录和注册控件。我在后面的代码中使用自定义函数(C#)

这个问题是由位置更改引起的吗? 开发机目录:C:\Users\Megatron\Documents\Visual Studio 2010\Projects\Osqar - v0.2\OSQARv0.1 Web 服务器目录:C:\inetpub\wwwroot\Osqar

我在这里有点迷失,所以任何建议将不胜感激。

这是网络配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!--
  For more information on how to configure your ASP.NET application, please visit
  http://go.microsoft.com/fwlink/?LinkId=169433
  -->
<configuration>
    <connectionStrings>
        <add name="dbConn" connectionString="data source=mssql.database.com; Initial Catalog=devworks_oscar;User ID=myusername;Password=password" providerName="System.Data.SqlClient" />
    </connectionStrings>
    <system.web>
        <authentication mode="Forms">
            <forms name="Osqar" loginUrl="/login/login.aspx" protection="All" path="/" timeout="60" />
        </authentication>

        <compilation debug="true" />
        <pages /></system.web>
    <system.webServer>
        <defaultDocument>
            <files>
                <add value="index.aspx" />
            </files>
        </defaultDocument>
    </system.webServer>
</configuration>

I have been working on a website project which restricts access to a certain folder to annonymous users and allows access to the folder to those who are logged in.
This has been working perfectly on my development machine.

However since publishing the website and deploying to a web server (Windows Server 2008, IIS7) the forms authentication appears not to be working. Anonymous users are able to access the "restricted" folder.
I have compared the webconfig on both the development machine and the web server and they are exactly the same.

I set up the access/restriction to the directory on the development machine using the Web Site Administration Tool built into the .NET Framework using this tutorial. However I understand this tool is localhost only?

Please note: I am not using the asp.net login and registration controls. I am using a custom function in the code behind (C#)

Is this problem caused by the change of location?
The development machine directory: C:\Users\Megatron\Documents\Visual Studio 2010\Projects\Osqar - v0.2\OSQARv0.1
The Web server Directory: C:\inetpub\wwwroot\Osqar

I am a little lost here so any advice would be greatly appreciated.

Here is the web config file

<?xml version="1.0" encoding="UTF-8"?>
<!--
  For more information on how to configure your ASP.NET application, please visit
  http://go.microsoft.com/fwlink/?LinkId=169433
  -->
<configuration>
    <connectionStrings>
        <add name="dbConn" connectionString="data source=mssql.database.com; Initial Catalog=devworks_oscar;User ID=myusername;Password=password" providerName="System.Data.SqlClient" />
    </connectionStrings>
    <system.web>
        <authentication mode="Forms">
            <forms name="Osqar" loginUrl="/login/login.aspx" protection="All" path="/" timeout="60" />
        </authentication>

        <compilation debug="true" />
        <pages /></system.web>
    <system.webServer>
        <defaultDocument>
            <files>
                <add value="index.aspx" />
            </files>
        </defaultDocument>
    </system.webServer>
</configuration>

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

如梦 2025-01-04 11:27:59

authorization 部分似乎丢失了(?)。您应该有类似的信息,

<authorization>
   <deny users="?" />
   <allow users="*" />
</authorization>

如果没有有关所需授权级别的信息(拒绝匿名用户),应用程序服务器将让每个人去任何地方。

The authorization section seems to be missing (?). You should have something like

<authorization>
   <deny users="?" />
   <allow users="*" />
</authorization>

Without the information about the required level of authorization (deny anonymous users), the application server will let everyone go everywhere.

南薇 2025-01-04 11:27:59

将其放在 主标记下,例如:

<configuration>
 <location path="~/RestrictedFolder">
  <system.web>
  <authorization>
    <deny users="?"/>
  </authorization>
  </system.web>
 </location>
....

如果要限制特定文件,请执行以下操作:

<location path="~/securedpage.aspx">
  <system.web>
  <authorization>
    <deny users="?"/>
  </authorization>
 </system.web>
</location>

对已部署项目中的 web.config 进行这些更改

或者,如 Wiktor 建议使用阻止匿名访问整个网站

将其放在 下(可能在 标记之前或之后)

<authorization>
  <deny users="?"/>
</authorization>

或者在项目的根目录下创建一个文件夹并放置安全页面里面那个文件夹。 R-单击文件夹添加新的 web.config 文件并将以下内容放在 标记下

<authorization>
  <deny users="?"/>
</authorization>

Put this under <cofiguraation> main tag like:

<configuration>
 <location path="~/RestrictedFolder">
  <system.web>
  <authorization>
    <deny users="?"/>
  </authorization>
  </system.web>
 </location>
....

if you're restricting specific files do:

<location path="~/securedpage.aspx">
  <system.web>
  <authorization>
    <deny users="?"/>
  </authorization>
 </system.web>
</location>

Do these changes to the web.config in the deployed project

Alternatively as Wiktor suggested use to block anonymous access to the website as a whole

put it under <system.web> possibly before or after <authentication> tag

<authorization>
  <deny users="?"/>
</authorization>

Or create a folder under the root of your project and put secured pages inside that folder. R-click on the folder add new web.config file and put the following under the <system.web> tag

<authorization>
  <deny users="?"/>
</authorization>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文