BizTalk 2020 — HTTP-запрос неавторизован со схемой проверки подлинности клиента «Согласование». Заголовок проверки подлинности получен/сервер был "согласован"

У нас есть оркестровка с использованием SendPort для вызова внутренней веб-службы, которая не находится на том же компьютере, что и BizTalk. Точно такое же приложение отлично работает в BizTalk 2016, но не работает в BizTalk 2020.

Описание ошибки: System.Net.WebException: HTTP-запрос неавторизован со схемой проверки подлинности клиента «Согласование». Заголовок аутентификации, полученный от сервера, был «Negotiate».

Я прочитал связанный вопрос в StackOverflow: "Запрос HTTP неавторизован со схемой аутентификации клиента "Negotiate". Заголовок аутентификации, полученный от сервера, был "Negotiate""

У нас есть поведение WCF, называемое bizTalkAddHttpheaders. Весь код был перекомпилирован с помощью .NET 4.7.2 для BizTalk 2020. Мы пробовали с поведением WCF и без него, которое обрабатывает TLS 1.2.

Можете ли вы упреждающе принудительно выполнить аутентификацию в своем поведении вместо использования Negotiate? «Аутентификация с согласованием автоматически выбирает между протоколом Kerberos и аутентификацией NTLM, в зависимости от доступности».

Dijkgraaf 28.04.2023 04:17

@Dijkgraaf Спасибо, но решил, см. ответ.

NealWalters 28.04.2023 18:05
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
2
92
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Оказывается, имя пользователя экземпляра хоста просто не было настроено для этого приложения.

На самом деле я перепутал, какой это SendPort, поскольку это конкретное приложение вызывало два совершенно разных внутренних веб-сервиса. Как только я увидел, что это другой порт отправки, я поместил его под узел приложения со старым идентификатором пользователя, и это сработало.

При установке BizTalk 2020 в нашей разработке мы изменили идентификатор пользователя наших экземпляров хоста, чтобы он соответствовал соглашениям об именовании, используемым в QA и PROD. Поэтому нам пришлось создать множество заявок в службу поддержки, чтобы обеспечить надлежащую безопасность.

Я не знаю, почему ошибка не могла просто сказать «Имя пользователя = xxxxxx не авторизован», ее было бы намного проще идентифицировать.

Другие вопросы по теме