#c# #asp.net-mvc-3
#c# #asp.net-mvc-3
Вопрос:
Я развертываю веб-приложение в MVC3, проблема в том, что стили не могут быть связаны с макетом, потому что требуется аутентификация, так что я могу для этого сделать ??. Нужна ли мне другая конфигурация в моем web.config?
Обновить
Итак, я изменил свой web.config, но все еще без работы, вот мой web.config
<?xml version="1.0"?>
<!--
For more information on how to configure your ASP.NET application, please visit
http://go.microsoft.com/fwlink/?LinkId=152368
-->
<configuration>
<connectionStrings>
<add name="ApplicationServices"
connectionString="data source=.SQLEXPRESS;Integrated Security=SSPI;AttachDBFilename=|DataDirectory|aspnetdb.mdf;User Instance=true"
providerName="System.Data.SqlClient" />
</connectionStrings>
<appSettings>
<add key="webpages:Version" value="1.0.0.0"/>
<add key="ClientValidationEnabled" value="true"/>
<add key="UnobtrusiveJavaScriptEnabled" value="true"/>
</appSettings>
<location path="Content">
<system.web>
<authorization>
<allow users="*" />
</authorization>
</system.web>
</location>
<location path="Scripts">
<system.web>
<authorization>
<allow users="*" />
</authorization>
</system.web>
</location>
<location path="js">
<system.web>
<authorization>
<allow users="*" />
</authorization>
</system.web>
</location>
<location path="Images">
<system.web>
<authorization>
<allow users="*" />
</authorization>
</system.web>
</location>
<system.web>
<compilation debug="true" targetFramework="4.0">
<assemblies>
<add assembly="System.Web.Abstractions, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Helpers, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Routing, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.Mvc, Version=3.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
<add assembly="System.Web.WebPages, Version=1.0.0.0, Culture=neutral, PublicKeyToken=31BF3856AD364E35" />
</assemblies>
</compilation>
<authentication mode="Forms">
<forms loginUrl="~/Account/LogOn" timeout="10" />
</authentication>
<membership>
<providers>
<clear/>
<add name="AspNetSqlMembershipProvider" type="System.Web.Security.SqlMembershipProvider" connectionStringName="ApplicationServices"
enablePasswordRetrieval="false" enablePasswordReset="true" requiresQuestionAndAnswer="false" requiresUniqueEmail="false"
maxInvalidPasswordAttempts="5" minRequiredPasswordLength="6" minRequiredNonalphanumericCharacters="0" passwordAttemptWindow="10"
applicationName="/" />
</providers>
</membership>
<profile>
<providers>
<clear/>
<add name="AspNetSqlProfileProvider" type="System.Web.Profile.SqlProfileProvider" connectionStringName="ApplicationServices" applicationName="/" />
</providers>
</profile>
<roleManager enabled="false">
<providers>
<clear/>
<add name="AspNetSqlRoleProvider" type="System.Web.Security.SqlRoleProvider" connectionStringName="ApplicationServices" applicationName="/" />
<add name="AspNetWindowsTokenRoleProvider" type="System.Web.Security.WindowsTokenRoleProvider" applicationName="/" />
</providers>
</roleManager>
<pages>
<namespaces>
<add namespace="System.Web.Helpers" />
<add namespace="System.Web.Mvc" />
<add namespace="System.Web.Mvc.Ajax" />
<add namespace="System.Web.Mvc.Html" />
<add namespace="System.Web.Routing" />
<add namespace="System.Web.WebPages"/>
</namespaces>
</pages>
</system.web>
<system.webServer>
<validation validateIntegratedModeConfiguration="false"/>
<modules runAllManagedModulesForAllRequests="true"/>
</system.webServer>
<runtime>
<assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
<dependentAssembly>
<assemblyIdentity name="System.Web.Mvc" publicKeyToken="31bf3856ad364e35" />
<bindingRedirect oldVersion="1.0.0.0-2.0.0.0" newVersion="3.0.0.0" />
</dependentAssembly>
</assemblyBinding>
</runtime>
</configuration>
обновление II
это метод моего контроллера
public ActionResult LogOn()
{
return View();
}
//
// POST: /Account/LogOn
[HttpPost]
public ActionResult LogOn(LogOnModel model, string returnUrl)
{
if (ModelState.IsValid)
{
clsEncriptacion _clsEncriptacion = new clsEncriptacion();
string encripPassword = _clsEncriptacion.Encriptar(model.Password);
Usuario user = (from U in _db.Usuario
where ((U.Nombre == model.UserName) amp;amp; (U.Password == encripPassword))
select U).FirstOrDefault();
if (user != null)
{
Session["IdPerfil"] = user.Perfil_FK.Nivel.ToString();
Session["IDUsuario"] = user.ID;
FormsAuthentication.RedirectFromLoginPage(user.Nombre, true);
return RedirectToAction("Index", "Home");
}
else
{
Session["IdPerfil"] = string.Empty;
ModelState.AddModelError("", "Login o password incorrecto. Por favor, intente nuevamente.");
}
}
// If we got this far, something failed, redisplay form
return View(model);
}
Нужна ли мне другая конфигурация в моем IIS??
Комментарии:
1. Как вы выполняете свою аутентификацию? Код, который проверяет только папку администратора, ограничен. Как вы это делаете?
2. я создаю свой собственный метод в контроллере
3. конечно… позвольте мне обновить свой вопрос
4. готово, вопрос был обновлен
5. Итак, после входа в систему как администратор вы можете просматривать ресурсы? Вы уверены, что URL указан правильно? Виден ли веб-сайт?
Ответ №1:
Попробуйте добавить следующее в свою веб-конфигурацию:
<location path="admin/asset">
<system.web>
<authorization>
<allow users="*"/>
</authorization>
</system.web>
</location>
предполагается admin/asset
, что вы размещаете свой css и изображения
Комментарии:
1. если я использую содержимое папки по умолчанию, оно должно работать, указывая только
"Content"
путь???2. Да. В /web.config вставьте <путь к местоположению=»Content»> <system.web> <авторизация> <разрешить пользователям=»*»/> </авторизация> </system.web> </location>
3. Я обновил свой вопрос, потому что добавил эту конфигурацию, но она не работает
Ответ №2:
Вам необходимо разрешить анонимный доступ к вашим ресурсам, иначе они не будут предоставлены.
В web.config используйте что-то вроде:
<configuration>
<location path="mystyles.css">
<system.web>
<authorization>
<allow users="*"/>
</authorization>
</system.web>
</location>
</configuration>