В настоящее время я работаю с устаревшим приложением .NET Framework, в котором есть веб-клиент (MVC) и мобильный клиент. Я успешно настроил свой проект для использования токенов-носителей для моих контроллеров webapi и файлов cookie сеанса для моего контроллера mvc, используя следующее в моем WebApiConfig.cs:
////Tells APIs to ignore the Default Cookie Type Authentication
config.SuppressDefaultHostAuthentication();
config.Filters.Add(newHostAuthenticationFilter(OAuthDefaults.AuthenticationType);
Однако в моих контроллерах MVC у меня есть некоторые методы, которые возвращают IActionResult(), а некоторые возвращают JSonResult. Можно ли определить атрибут/authshcema для каждого метода контроллера, который позволил бы моим методам контроллера JsonResult использовать токены-носители вместо сеансов файлов cookie, несмотря на то, что они не находятся внутри контроллера webapi ?? Это позволило бы мне вызывать эти методы контроллера из моего мобильного клиента и сэкономило бы мне много времени на реорганизацию этих методов в отдельные контроллеры.
Пример:
//MVC Controller (Not Web API)
public class HomeController : Controller
{
//Should use cookie session
public ActionResult Index()
{
return View();
}
//Should use bearer tokens
[HttpGet]
public JsonResult GetPrograms()
{
var menu = _menuService.GetMenu();
return new JsonResult
{
Data = menu,
JsonRequestBehavior = JsonRequestBehavior.AllowGet
};
}
}
Вы правы в том, что слово «запуск», вероятно, сбивает с толку, поэтому я удалил его, так как оно не имеет ничего общего с Core. В противном случае я фактически говорю как о MVC, так и о WebAPI, поскольку одно и то же решение может содержать оба (с использованием разных методов аутентификации), мой вопрос касается объединения двух, я считаю, что это совершенно ясно.
Для IdentityServer4 требуется ASP.NET Core, так зачем вы добавили этот тег? Ваш вопрос все еще совершенно неясен, мы не можем читать ваши мысли
Токены выпускаются из IdS4, но проверяются с помощью IdS3. Измененный





Ваш вопрос совершенно не ясен. Казалось, что вы говорите об ASP.NET MVC, ASP.NET WebAPI и ASP.NET Core, но вам не ясно, в чем ваша проблема. У меня нет идей, почему вы упоминаете свой «запуск» (термин ASP.NET Core), а затем публикуете код веб-API ASP.NET. Пожалуйста, редактировать свой вопрос и уточните его