HTTPWebRequest «PUT» состояние ошибки 405 Метод не разрешен в IIS7 - PullRequest
9 голосов
/ 24 августа 2011

Мое приложение использует метод «Put» HttpWebRequest для загрузки файла в приложения asp.net, размещенные в iis7.У меня была ошибка Код состояния 405 Метод не разрешен.Я перепробовал все решения, которые могу найти на форуме в течение 2 дней, включая удаление webDav в обработчиках, добавление метода «Put» в обработчики (как в http://blogs.msdn.com/b/joseph_fultz/archive/2009/07/23/enabling-the-put-verb-with-handlers-and-iis-7-0.aspx),, перерегистрация asp.net в iisНо ни одно из решений не работает в моем случае.

Я запускаю отслеживание Failed Request в iis, и ниже ошибка:

MODULE_SET_RESPONSE_ERROR_STATUS
ModuleName  StaticFileModule
Notification    128
HttpStatus  405
HttpReason  Method Not Allowed
HttpSubStatus   0
ErrorCode   2147942401
ConfigExceptionInfo     
Notification    EXECUTE_REQUEST_HANDLER
ErrorCode   Incorrect function. (0x80070001)
    MODULE_SET_RESPONSE_ERROR_STATUS
Warning     

ModuleName="StaticFileModule", Notification="EXECUTE_REQUEST_HANDLER", HttpStatus="405", HttpReason="Method Not Allowed", HttpSubStatus="0", ErrorCode="Incorrect function

Любая помощь высоко ценится. Спасибо. Мой аспПриложения / форма .net были разработаны с использованием Visual Studio 2008 и опубликованы в iis 7.

--------------------------------------- ОБНОВЛЕНИЕ

Ниже приведен код для обработки запроса HttpWebRequest (PUT): он взял токен аутентификации пользователя и проверил его. После этого он создал билет аутентификации и ответназад к пользователю.

     tokenSignature = false;

        //To capture the tokenId
        string MainString = Request.Headers.ToString();
        int FirstChr = MainString.IndexOf("*=");
        MainString = MainString.Substring(FirstChr + 2);
        int secondChr = MainString.IndexOf("%");
        tokenId = MainString.Substring(0, secondChr);


        //to Write the received encrypted token into temporary folder
        FileStream fs = new FileStream(AppsConfig.temp + tokenId, FileMode.Create);
        BinaryWriter bw = new BinaryWriter(fs);

        //Convert the listenerRequest into InputStream to write the token
        Stream InputStream = Request.InputStream;
        byte[] inData = new byte[32768];
        int bytesRead;

        while ((bytesRead = InputStream.Read(inData, 0, inData.Length)) > 0)
        {
            bw.Write(inData, 0, bytesRead);
        }

        //close the connection that is used to write the token
        bw.Close();
        fs.Close();

        //Read the temporary encrypted token (for decryption purposes)
        fin = File.OpenRead(AppsConfig.temp + tokenId);

        //To read the private key
        Stream prSignKey = File.OpenRead(AppsConfig.privateKey);
        PgpSecretKey pgpSec;
        PgpSecretKeyRingBundle ringBundle = new PgpSecretKeyRingBundle(PgpUtilities.GetDecoderStream(prSignKey));

        //Get the company key Id and passphrase
        String[] getText = new String[2];
        int no = 0;
        TextReader readFile = new StreamReader(AppsConfig.keyFile);

        do
        {
            getText[no] = readFile.ReadLine();
            no++;
        } while (no < 2);
        readFile.Close();
        long KeyId = Int64.Parse(getText[0]);
        Char[] passwd = getText[1].ToCharArray();
        //Get the private key
        pgpSec = ringBundle.GetSecretKey(KeyId);
        PgpPrivateKey pgpPrivate = pgpSec.ExtractPrivateKey(passwd);

        //Close all unnecessary connections
        InputStream.Close();
        prSignKey.Close();
        readFile.Close();

        //Call the decrypt method to decrypt the token
        decryptFile(fin, pgpPrivate, "original.xml", tokenId);

        if (tokenSignature == true)
        {
            //Create the authentication cookie and add this cookie to the httpResponse
            //This authentication cookie would be used to access the resource.aspx
            HttpCookieCollection cc = Response.Cookies;
            FormsAuthentication.SetAuthCookie(tokenId, false);
            cc = Response.Cookies;

        //remove the temporary file that was created earlier.
            File.Delete(AppsConfig.temp + tokenId);
            File.Delete(AppsConfig.temp + tokenId + ".bin");
        }
        else
        {
            Server.Transfer("~/Error.aspx?errorMessage=" + "SignatureFailed");

        }

Ответы [ 2 ]

13 голосов
/ 11 августа 2012

Есть несколько путей, чтобы решить эту проблему:

1) Полностью удалить WebDAV с сервера. Вы можете сделать это из приложения Windows Добавить / Удалить функции. Это потребует перезагрузки.

2) Второе решение простое. A) Перейдите на сайт IIS и щелкните модули. Найдите модуль WebDAV и удалите его.

Теперь вы все еще можете использовать WebDAV на других своих сайтах и ​​не мешать использованию метода PUT на этом сайте.

enter image description here

B) Вам может понадобиться найти правильное отображение обработчика и добавить глагол PUT.

1 голос
/ 25 августа 2011

Я не думаю, что проблема в вашем коде ... если глагол PUT не разрешен, ни один клиент не сможет PUT файлы. Это также не говорит «Несанкционированный», что было бы в случае проблемы с разрешениями ... Я думаю, что это все еще конфигурация IIS. Проверьте эту ссылку:

http://support.microsoft.com/kb/942051/en-us

Чтобы упростить себе задачу, вы можете проверить этот инструмент, который, как я слышал, хорош для этого:

http://www.microsoft.com/download/en/details.aspx?displaylang=en&id=21625

НТН.

...