Ответы пользователя по тегу ASP.NET
  • Как сократить запись Dynamic LINQ Order BY?

    andrewpianykh
    @andrewpianykh
    Func<Article, object> orderByFunc = (a) => 
       typeof(Article).GetProperty(OrderBy).GetValue(a);
    Ответ написан
  • Ошибка синтаксического анализатора(ASP.NET MVC), что делать?

    andrewpianykh
    @andrewpianykh
    Соответствие пространств имен в Global.asax.cs и Global.asax проверьте. Должно быть GameStore.MvcApplication.
    Ответ написан
    1 комментарий
  • Автоматический разогрев сервера IIS ASP.NET MVC?

    andrewpianykh
    @andrewpianykh
    Можно воспользоваться сервисами для проверки доступности, например, https://uptimerobot.com/ (бесплатно до 50 сайтов).
    Создайте монитор HTTP и установите периодичность проверки в 5-15 минут.
    Это не позволит вашему сервису "заснуть")
    Ответ написан
    1 комментарий
  • Как настроить SMTP ASP.NET?

    andrewpianykh
    @andrewpianykh
    Пробуйте 25 порт, у меня через 465 тоже не работало как-то.
    Ответ написан
    Комментировать
  • Несоответствие валидации на сервере и клиенте. ASP.NET MVC?

    andrewpianykh
    @andrewpianykh
    Задайте русскую культуру на сервере в файле web.config в system.web
    <globalization culture="ru-Ru" uiCulture="ru" />

    Также для даты можно попробовать добавить в модель аттрибут
    [DisplayFormat(DataFormatString = "{0:dd/MM/yyyy}"]

    stackoverflow.com/questions/18548816/mvc-4-date-cu...
    Ответ написан
    Комментировать
  • Как настроить права доступа в файле web.config?

    andrewpianykh
    @andrewpianykh
    На мой взгляд в MVC лучше использовать AuthorizeAttribute

    [Authorize]
    public ActionResult Index()
    {
        ...
    }
    
    [Authorize (Users="admin")]
    public ActionResult Edit()
    {
        ...
    }
    Ответ написан
    4 комментария
  • Почему не работает связь много-ко-многим?

    andrewpianykh
    @andrewpianykh
    В Вашем случае явно создавать таблицу связей не нужно, она будет создана автоматически

    public class College
        {
            public int? AccrLevel { get; set; }
    
            public string Address { get; set; }
    
            public virtual Area Area { get; set; }
    
            public int AreaId { get; set; }
    
            public bool? Demo { get; set; }
    
            public virtual Director Director { get; set; }
    
            public int DirectorId { get; set; }
    
            public string Email { get; set; }
    
            public bool? Full { get; set; }
    
            [Key]
            public int CollegeId { get; set; }
    
            public string Locality { get; set; }
    
            public virtual LocalityType LocalityType { get; set; }
    
            public int LocalityTypeId { get; set; }
    
            public string Name { get; set; }
    
            public string Phone { get; set; }
    
            public string Site { get; set; }
    
            public virtual ICollection<Speciality> Specialities { get; set; }
    
            public virtual Status Status { get; set; }
    
            public int? StatusId { get; set; }
    
            public virtual University University { get; set; }
    
            public int? UniversityId { get; set; }
        }
    
        public class Speciality
        {
            public virtual ICollection<College> Colleges { get; set; }
    
            [ForeignKey("DirectionCode")]
            public virtual Direction Direction { get; set; }
    
            public string DirectionCode { get; set; }
    
            public string Name { get; set; }
    
            [Key]
            public string SpecialityCode { get; set; }
        }


    Подробнее: www.entityframeworktutorial.net/code-first/configu...
    Ответ написан
  • Как работать со связью много-ко-многим в контроллере?

    andrewpianykh
    @andrewpianykh
    Как строка может сравниваться со списком строк?

    Используйте методы Contains и Count чтобы проверить наличие строки в списке.

    var list = new List<string>() { "one", "two", "three", "four" };
    var expected = "two";
    var result = list.Contains(expected);
    // либо
    result = list.Count(a => a == expected) > 0;


    В Вашем случае, например так:

    var regions = new List<string>() { "region 1", "region 2", "region 3", "region 4" };
    repository.Colleges.Where(college => regions.Count(a =>  a == college.Area.Region.Name) > 0);
    Ответ написан
    Комментировать
  • Как обработать все ошибки (перехваченные и неперехваченные) в ASP.Net MVC?

    andrewpianykh
    @andrewpianykh
    Я предпочитаю следующий подход:

    1. Создаем контроллер ErrorController, например так:

    public class ErrorController
    {
    	public virtual ActionResult BadRequest()
    	{
    		return View();
    	}
    
    	public virtual ActionResult Forbidden()
    	{
    		return View();
    	}
    
    	public virtual ActionResult Index()
    	{
    		return View();
    	}
    
    	public virtual ActionResult NotFound()
    	{
    		return View();
    	}
    }


    2. Добавляем вьюхи

    3. Создаем свой расширенный HandleErrorAttribute, например так:

    public class ExtHandleErrorAttribute : HandleErrorAttribute
    {
    	//private readonly ILogger logger;
    
    	public ExtHandleErrorAttribute(/*ILogger logger*/)
    	{
    		//this.logger = logger;
    	}
    
    	public override void OnException(ExceptionContext filterContext)
    	{
    		if (filterContext.ExceptionHandled || !filterContext.HttpContext.IsCustomErrorEnabled)
    		{
    			return;
    		}
    
    		if (new HttpException(null, filterContext.Exception).GetHttpCode() != 500)
    		{
    			return;
    		}
    
    		if (!ExceptionType.IsInstanceOfType(filterContext.Exception))
    		{
    			return;
    		}
    
    		if (filterContext.HttpContext.Request.Headers["X-Requested-With"] == "XMLHttpRequest")
    		{
    			filterContext.Result = new JsonResult
    			{
    				JsonRequestBehavior = JsonRequestBehavior.AllowGet,
    				Data = new
    				{
    					error = true,
    					message = filterContext.Exception.Message
    				}
    			};
    		}
    		else
    		{
    			var controllerName = (string)filterContext.RouteData.Values["controller"];
    			var actionName = (string)filterContext.RouteData.Values["action"];
    			var model = new HandleErrorInfo(filterContext.Exception, controllerName, actionName);
    
    			filterContext.Result = new ViewResult
    			{
    				ViewName = View,
    				MasterName = Master,
    				ViewData = new ViewDataDictionary<HandleErrorInfo>(model),
    				TempData = filterContext.Controller.TempData
    			};
    		}
    
    		//var e = filterContext.Exception;
    		//logger.Error(e, e.Message);
    
    		filterContext.ExceptionHandled = true;
    		filterContext.HttpContext.Response.Clear();
    		filterContext.HttpContext.Response.StatusCode = 500;
    		filterContext.HttpContext.Response.TrySkipIisCustomErrors = true;
    	}
    }


    4. Регистрируем глобальный фильтр:
    public class FilterConfig
    {
    	public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    	{
    		var extHandleErrorAttribute = DependencyResolver.Current.GetService<ExtHandleErrorAttribute>();// new ExtHandleErrorAttribute();
    		filters.Add(extHandleErrorAttribute);
    	}
    }


    5. В Global.asax.cs добавляем метод Application_Error:

    protected void Application_Error(object sender, EventArgs e)
    {
    	var httpContext = ((MvcApplication)sender).Context;
    
    	var currentRouteData = RouteTable.Routes.GetRouteData(new HttpContextWrapper(httpContext));
    	var currentController = " ";
    	var currentAction = " ";
    
    	if (currentRouteData != null)
    	{
    		if (currentRouteData.Values["controller"] != null && !String.IsNullOrEmpty(currentRouteData.Values["controller"].ToString()))
    		{
    			currentController = currentRouteData.Values["controller"].ToString();
    		}
    
    		if (currentRouteData.Values["action"] != null && !String.IsNullOrEmpty(currentRouteData.Values["action"].ToString()))
    		{
    			currentAction = currentRouteData.Values["action"].ToString();
    		}
    	}
    
    	var ex = Server.GetLastError();
    
    	var controller = new ErrorController();
    	var routeData = new RouteData();
    	var action = "Index";
    
    	if (ex is HttpException)
    	{
    		var httpEx = ex as HttpException;
    
    		switch (httpEx.GetHttpCode())
    		{
    			case 404:
    				action = "NotFound";
    				break;
    
    			case 403:
    				action = "Forbidden";
    				break;
    
    			case 400:
    				action = "BadRequest";
    				break;
    
    			default:
    				action = "Index";
    				//var logger = DependencyResolver.Current.GetService<ILogger>();
    				//logger.Error(ex, ex.Message);
    				break;
    		}
    	}
    
    	httpContext.ClearError();
    	httpContext.Response.Clear();
    	httpContext.Response.StatusCode = ex is HttpException ? ((HttpException)ex).GetHttpCode() : 500;
    	httpContext.Response.TrySkipIisCustomErrors = true;
    	routeData.Values["controller"] = "Error";
    	routeData.Values["action"] = action;
    
    	controller.ViewData.Model = new HandleErrorInfo(ex, currentController, currentAction);
    	((IController)controller).Execute(new RequestContext(new HttpContextWrapper(httpContext), routeData));
    }


    6. В web.config добавляем в system.web
    <customErrors mode="On" />

    также в system.webServer можно добавить:

    <httpErrors>
      <remove statusCode="400" subStatusCode="-1" />
      <remove statusCode="403" subStatusCode="-1" />
      <remove statusCode="502" subStatusCode="-1" />
      <remove statusCode="501" subStatusCode="-1" />
      <remove statusCode="500" subStatusCode="-1" />
      <remove statusCode="404" subStatusCode="-1" />
      <error statusCode="400" prefixLanguageFilePath="" path="/Error/BadRequest" responseMode="ExecuteURL" />
      <error statusCode="404" prefixLanguageFilePath="" path="/Error/NotFound" responseMode="ExecuteURL" />
      <error statusCode="500" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="501" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="502" prefixLanguageFilePath="" path="/Error" responseMode="ExecuteURL" />
      <error statusCode="403" prefixLanguageFilePath="" path="/Error/Forbidden" responseMode="ExecuteURL" />
    </httpErrors>
    Ответ написан
    Комментировать
  • ASP .NET MVC Entity Framework в чем ошибка и как исправить?

    andrewpianykh
    @andrewpianykh
    В Вашем случаем можно упростить код и обойтись без указания атрибутов:

    public class Area // Район
    {
    	public int Id { get; set; }
    	public string Name { get; set; }
    	public int RegionId { get; set; }		
    	public virtual Region Region {get; set;}
    	public byte[] Map { get; set; }
    }
    
    public class Region // Область
    {
    	public int Id { get; set; }
    	public string Name { get; set; }
    	public byte[] Map { get; set; }
    }


    иначе:

    public class Area // Район
    {
    	[Key]
    	public int AreaId { get; set; }
    	public string Name { get; set; }
    	public int RegionId { get; set; }	
    	[ForeignKey("RegionId")] 	
    	public virtual Region Region {get; set;}
    	public byte[] Map { get; set; }
    }
    
    public class Region // Область
    {
    	[Key]
    	public int RegionId { get; set; }
    	public string Name { get; set; }
    	public byte[] Map { get; set; }
    }


    Подробнее
    www.entityframeworktutorial.net/code-first/foreign...
    https://msdn.microsoft.com/ru-ru/data/gg193958.aspx
    andrey.moveax.ru/post/mvc3-in-depth-entity-framewo...
    Ответ написан
    1 комментарий