У меня есть небольшое клиентское/серверное тестовое приложение, в котором у меня есть приложение Flex, которое делает HTTP-запрос серверного приложения. Серверное приложение - это script, работающее на моем локальном компьютере, прослушивающее порт 8001. Клиент - это swf, который я запускаю локально, и использует mx.rpc.http.HTTPService
для запроса страницы.
Настройка HTTPService выполняется следующим образом:
_HttpService = new HTTPService();
_HttpService.url = "http://localhost:8001";
_HttpService.contentType = "text/xml";
Когда я делаю основной запрос страницы, мое серверное приложение сначала получает запрос "GET /crossdomain.xml HTTP/1.1"
, который терпит неудачу, так как у меня нет файла crossdomain.xml. Причина, по которой у меня нет такой возможности, заключается в том, что все это происходит на моей локальной машине (на данный момент), и я не нуждаюсь в ней (я не думаю).
Я определенно работал над этим кодом без использования crossdomain.xml, когда использовал Flex 3.x. Я думал, что я работал с Flex 4. Теперь я использую Flex 4.5. Есть ли проблема здесь, возможно, из-за изменений политики безопасности?
Что все это происходит на localhost, почему Flash Player запрашивает файл crossdomain.xml?
В случае, если это помогает, конкретная ошибка, которую возвращает мой AsyncResponder:
[FaultEvent fault=[RPC Fault faultString="Security error accessing url" faultCode="Channel.Security.Error" faultDetail="Destination: DefaultHTTP"] messageId="F43DCBFF-E99A-99CC-57D8-535C13C7CD48" type="fault" bubbles=false cancelable=true eventPhase=2]