Как устранить эту ошибку HTTP ASP.NET MVC 5, возникающую для конкретной страницы? - PullRequest
0 голосов
/ 13 декабря 2018

Я понимаю, что этот общий вопрос задавался и отвечался здесь много раз.Первоначально эта проблема возникла для всех моих веб-страниц.Я, вероятно, попробовал 15 различных предлагаемых исправлений здесь.В конце концов, используя ответ на аналогичный вопрос, я поставил галочку «Переопределить корневой URL-адрес приложения», и теперь моя домашняя страница и страница о странице загружаются правильно.Однако проблема сохраняется для моих страниц «Фильмы» и «Рейтинги», которые почти одинаковы, что означает, что это, скорее всего, код.Я явно что-то упускаю, и я очень новичок в использовании c #, поэтому я очень помог бы!

Это ошибка:

Ошибка сервера в приложении '/'.Этот ресурс не может быть найден.Описание: HTTP 404. Ресурс, который вы ищете (или одна из его зависимостей), мог быть удален, изменилось его имя или временно недоступен.Пожалуйста, просмотрите следующий URL и убедитесь, что он написан правильно.

Запрошенный URL: / Фильмы

Вот мой контроллер фильмов:

using System;
using System.Collections.Generic;
using System.Data;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Threading.Tasks;
using System.Web.Http;
using System.Web.Http.Description;
using AllMovies.DAL;
using AllMovies.Models;

namespace AllMovies.Controllers
{
    public class MoviesController : ApiController
    {
        private AllMoviesContext db = new AllMoviesContext();

        // GET: api/Movies
        public IQueryable<MovieDTO> GetMovies()
        {
            var movies = from m in db.Movies
                         select new MovieDTO()
                         {
                             Id = m.Id,
                             Name = m.Name,
                             Genre = m.Genre,
                             Budget = m.Budget,
                             Overview = m.Overview,
                             release_date = m.release_date,
                             Ratings = m.Ratings.Select(r => new RatingDTO()
                             {
                                 Id = r.Id,
                                 userId = r.userId,
                                 rating_score = r.rating_score
                             }
                             ).ToList()
                         };

            return movies;
        }


        // GET: api/Movies/5
        [ResponseType(typeof(MovieDTO))]
        public async Task<IHttpActionResult> GetMovies(int id)
        {
            Movie m = await db.Movies.FindAsync(id);
            if (m == null)
            {
                return NotFound();
            }
            MovieDTO movie = new MovieDTO
            {
                Id = m.Id,
                Name = m.Name,
                Genre = m.Genre,
                Budget = m.Budget,
                Overview = m.Overview,
                release_date = m.release_date,
                Ratings = m.Ratings.Select(r => new RatingDTO()
                {
                    Id = r.Id,
                    userId = r.userId,
                    rating_score = r.rating_score
                }
                ).ToList()
            };

            return Ok(movie);
        }

        // PUT: api/Movies/5
        [ResponseType(typeof(void))]
        public async Task<IHttpActionResult> PutMovies(int id, Movie movie)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }

            if (id != movie.Id)
            {
                return BadRequest();
            }

            db.Entry(movie).State = EntityState.Modified;

            try
            {
                await db.SaveChangesAsync();
            }
            catch (DbUpdateConcurrencyException)
            {
                if (!MovieExists(id))
                {
                    return NotFound();
                }
                else
                {
                    throw;
                }
            }

            return StatusCode(HttpStatusCode.NoContent);
        }

        // POST: api/Movies
        [ResponseType(typeof(Movie))]
        public async Task<IHttpActionResult> PostMovies(Movie movie)
        {
            if (!ModelState.IsValid)
            {
                return BadRequest(ModelState);
            }

            db.Movies.Add(movie);
            await db.SaveChangesAsync();

            return CreatedAtRoute("DefaultApi", new { id = movie.Id }, movie);
        }

        // DELETE: api/Movies/5
        [ResponseType(typeof(Movie))]
        public async Task<IHttpActionResult> DeleteMovie(int id)
        {
            Movie movie = await db.Movies.FindAsync(id);
            if (movie == null)
            {
                return NotFound();
            }

            db.Movies.Remove(movie);
            await db.SaveChangesAsync();

            return Ok(movie);
        }

        protected override void Dispose(bool disposing)
        {
            if (disposing)
            {
                db.Dispose();
            }
            base.Dispose(disposing);
        }

        private bool MovieExists(int id)
        {
            return db.Movies.Count(e => e.Id == id) > 0;
        }
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...