Arhn - архитектура программирования

Разрешение закодированных символов в MVC Get

У меня есть контроллер MVC со следующим методом

    [HttpGet]
    public ActionResult Image(int image, string message)
    {

Я хочу, чтобы это был GET, потому что это подходящий глагол для метода, который я реализую.

Я хочу предоставить "Это работает?" в качестве параметра метода. Очевидно, что это не сработает:

http://localhost:55197/Controller/Image/3/Does%20this%20work?

Знак вопроса считается частью строки запроса и удаляется. Я прочитал этот вопрос, в котором предлагается кодировать вопросительный знак к %3F, для меня это имеет смысл (в конце концов, мы кодируем наши пробелы). Однако, когда я вызываю метод с этой строкой запроса:

http://localhost:55197/Controller/Image/3/Does%20this%20work%3F

я получил

От клиента было обнаружено потенциально опасное значение Request.Path (?).

Я прочитал этот вопрос, который предлагает использовать [AllowHtml], но его можно использовать только для свойств (и поэтому он больше подходит для запросов POST.

Как передать строки типа:

Это работает?

Я так думаю...

В этот метод?

16.05.2015

Ответы:


1

Попробуйте использовать приведенный ниже код в файле web.config: -

<system.web>
    <httpRuntime requestPathInvalidCharacters="" requestValidationMode="2.0" />
    <pages validateRequest="false" />
</system.web>
16.05.2015
  • Это кажется очень радикальным, можете ли вы рассказать о последствиях для безопасности отключения проверки всех запросов!? 16.05.2015
  • @Liath.. Ну да ... вы должны указать настройки в web.config, как показано выше ... другого варианта нет. 18.05.2015
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..