authentication mode="Forms"时,为何Login页面图片无法表示?

kinlin 2008-06-10 05:21:19
我的web.config是如下配置的:
<authentication mode="Forms">
<forms loginUrl="./KYOUTSUU/Login.aspx" slidingExpiration="true"></forms>
</authentication>
<authorization>
<deny users="?"/>
</authorization>
但当我运行时,Login页面的图片全是叉,没有表示出来,不知为何?是不是我哪处没有配置,还请高手赐教。谢谢
...全文
630 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
落魄的WP开发 2010-09-30
  • 打赏
  • 举报
回复
dfd
amandag 2008-06-10
  • 打赏
  • 举报
回复
这个问题N多人问过

请参看
http://topic.csdn.net/u/20080505/23/95f95909-bbe9-43bf-b62c-905d0b1515dd.html
amandag 2008-06-10
  • 打赏
  • 举报
回复
也可以这样

<location path="xxx.css">
<system.web>
<authorization>
<allow users="*"/>
</authorization>
</system.web>
</location>

<location path="images">
<system.web>
<authorization>
<allow users="*"/>
</authorization>
</system.web>
</location>
amandag 2008-06-10
  • 打赏
  • 举报
回复
方法1

因为你拒绝了所有的匿名用户访问你的资源
<deny users="?" />

现在用户连注册都没机会了

1、 新建一个目录 Public ,用于存放一些公用的文件,如你Login.aspx中所有的图片
2、 右击点击目录 Public ,新增一个 Web.config
内容如下:


<?xml version="1.0" encoding="utf-8"?>
<configuration>
<system.web>
<authorization><allow users="*"/></authorization>
</system.web>
</configuration>




上面这个 Web.config 将替代根目录 Web.config 中的 <authorization> 节点设置,即:

<allow users="*"/> 替换 <deny users="?"> </deny>

因此,处于 Public 目录下的文件,允许所有人浏览,包括未验证的用户。
如果有Register.aspx也请放入此目录
kinlin 2008-06-10
  • 打赏
  • 举报
回复
那怎样才能不放开,而且能解决上记的问题呢? 是不是需要配置IIS,而且还报脚本错误,提示语法错误
chinahnzl 2008-06-10
  • 打赏
  • 举报
回复
晕..老打错字..应该是个别你需要的目录..或者是文件..允许匿名访问..
chinahnzl 2008-06-10
  • 打赏
  • 举报
回复
1楼说得对..你把整个都阻止了..肯定不能显示啊..

要把个别人目录..或者是个别文件显示出来..
sbqcel 2008-06-10
  • 打赏
  • 举报
回复
你要在configuration节点里做一些其他配置,将不需要登陆就能访问的资源给开放出来
如下不需要登陆即可访问Images文件夹的资源:
<location path="Images">
<system.web>
<authorization>
<allow users="*"/>
</authorization>
</system.web>
</location>
ASP.NET Forms验证 实现子域名(SubDomain)共享登陆 http://www.cnblogs.com/Medi-Bruce/archive/2010/01/17/1650027.html 一、什么是单点登录    单点登录就是在多个web应用程序中,实现统一登录方式,一但登录了某web应用程序,其它相关联的web应用程 序都无需再次登录,一个地方退出,所有相关联的web应用程序都退出. 二、通过利用ASP.NET Forms验证模式 可以实现子域名(SubDomain)共享登陆下的缺陷 要利用Asp.NET Form验证模式实现 同一主域下不同子域名共享登陆状态需要进行以下配置 配置Web.config 1.把Asp.net的认证模式改为Forms认证模式,domain 要等于你的应用程序对应的域名,例如: .test.cn <authentication mode="Forms"> <forms name=".ASPNETFORM" domain=".test.cn" loginUrl="/login.aspx" defaultUrl="/default.aspx" protection="All" timeout="30" path="/" requireSSL="false" slidingExpiration="true" enableCrossAppRedirects="false" cookieless="UseDeviceProfile" /> authentication> 2.配置针对存储在cookie中的票据信息进行加密解密的方式 备注:生成machineKey网址     http://www.aspnetresources.com/tools/keycreator.aspx 登陆创建验证票据 1.应用程序登陆页面(Login.aspx)输入用户名、密码并验证通过后,创建一张加密过的验证票据,并存储在cookie中 //创建验证票 FormsAuthenticationTicket ticket = new FormsAuthenticationTicket(1, name, DateTime.Now, DateTime.Now.AddDays(1d), false, HttpContext.Current.Request.UserHostAddress ); string authTicket = FormsAuthentication.Encrypt(ticket); HttpCookie cookie = new HttpCookie(FormsAuthentication.FormsCookieName, authTicket); cookie.Domain = ConfigurationManager.AppSettings["SSODomain"]; HttpContext.Current.Response.Cookies.Add(cookie); 2.登陆完毕后进入有权限的页面,并可得到验证通过后的ID User.Identity.Name; if (!User.Identity.IsAuthenticated) { //未登录 Response.Redirect("/login.aspx"); } string name = User.Identity.Name; 3.登出页面,清空用户信息,并销毁票据 HttpContext.Current.Session.Clear(); FormsAuthentication.SignOut(); 三、Forms验证 实现子域名(SubDomain)共享登陆下的缺陷 根据以上讲解,均可实现同一主域名下的多个子域名共享登陆状态,但是主域名有所限制,当主域名为1个字母,而后缀为2个字母的域名,不能通过认证,例如:a.cn域名,a.jp域名 均不能实现子域名共享登陆,而其他域名均能实现,例如:a.test.com, a.sina.cn 等,大家亦可通过修改hosts文件试验一下,如有高手知道怎么解决这个问题的,请指教,谢谢!!并附上 Demo程序 ,请大家指教! PS:因本人公司的域名为p.cn,想通过Form认证的模式实现子域名共享登陆状态,但是死活用不上!~~!!汗,不知道这个算不算微软的Bug。

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧