Messaggio di errore quando un utente accede a un sito Web di SharePoint pubblicato in ISA Server 2006 o In Windows Essential Business Server 2008: "HTTP 401 non autorizzato"

Sintomi

Quando un utente accede a un sito Web di SharePoint pubblicato in Microsoft Internet Security and Acceleration (ISA) Server 2006, ISA Server 2006 SP1 o Windows Essential Business Server 2008, l'utente potrebbe ricevere uno dei seguenti messaggi di errore: Messaggio dierrore 1

HTTP 401 Non autorizzato

Messaggio di errore 2

HTTP 500 Il server ha negato l'URL (Uniform Resource Locator) specificato. Contattare l'amministratore del server.

Questo problema si verifica in presenza delle seguenti condizioni:

  • Nel listener Web utilizzato dalla regola di pubblicazione Web di SharePoint viene configurata l'autenticazione basata su form HTML.

  • Il client Web invia una richiesta POST al sito Web di SharePoint.

  • L'URL della richiesta POST contiene caratteri estesi. Ad esempio, l'URL contiene é, à o è.

Causa

Questo problema si verifica perché ISA Server o Windows Essential Business Server 2008 impossibile analizzare un URL che contiene caratteri estesi. In questo caso, ISA Server o Windows Essential Business Server 2008 rifiuta la richiesta POST inviata dal client.

Risoluzione

Per risolvere questo problema, attenersi alla seguente procedura:

  1. Applicare l'hotfix descritto nell'articolo della Microsoft Knowledge Base 940250. Per ulteriori informazioni, fare clic sul seguente numero di articolo per visualizzare l'articolo della Microsoft Knowledge Base:

    940250 descrizione del pacchetto hotfix di ISA Server 2006: 16 luglio 2007

  2. Copiare lo script seguente nel Blocco note:Nota Per risolvere il problema in ISA Server 2006, utilizzare lo script seguente. Non è necessario applicare l'hotfix in questo articolo per ISA Server 2006 SP1, ma è necessario utilizzare lo script.

    Const SE_VPS_GUID = "{143F5698-103B-12D4-FF34-1F34767DEabc}"Const SE_VPS_NAME = "CookieFilterDecodeUEncoding"Const SE_VPS_VALUE = trueSub SetValue()    ' Create the root object.    Dim root  ' The FPCLib.FPC root object    Set root = CreateObject("FPC.Root")    'Declare the other objects that are needed.    Dim array       ' An FPCArray object    Dim VendorSets  ' An FPCVendorParametersSets collection    Dim VendorSet   ' An FPCVendorParametersSet object    ' Get references to the array object    ' and to the network rules collection.    Set array = root.GetContainingArray    Set VendorSets = array.VendorParametersSets    On Error Resume Next    Set VendorSet = VendorSets.Item( SE_VPS_GUID )    If Err.Number <> 0 Then        Err.Clear        ' Add the item        Set VendorSet = VendorSets.Add( SE_VPS_GUID )        CheckError        WScript.Echo "New VendorSet added... " & VendorSet.Name    Else        WScript.Echo "Existing VendorSet found... value- " &  VendorSet.Value(SE_VPS_NAME)    End If    if VendorSet.Value(SE_VPS_NAME) <> SE_VPS_VALUE Then        Err.Clear        VendorSet.Value(SE_VPS_NAME) = SE_VPS_VALUE        If Err.Number <> 0 Then            CheckError        Else            VendorSets.Save false, true            CheckError            If Err.Number = 0 Then                WScript.Echo "Done with " & SE_VPS_NAME & ", saved!"            End If        End If    Else        WScript.Echo "Done with " & SE_VPS_NAME & ", no change!"    End IfEnd SubSub CheckError()    If Err.Number <> 0 Then        WScript.Echo "An error occurred: 0x" & Hex(Err.Number) & " " & Err.Description        Err.Clear    End IfEnd SubSetValue
  3. Salvare il file come file di script di Microsoft Visual Basic utilizzando l'estensione vbs. Ad esempio, salvare il file utilizzando il nome seguente:

    EnableKB940248.vbs

  4. Al prompt dei comandi, passare al percorso in cui è stato salvato il file EnableKB940248.vbs.

  5. Eseguire il comando qui riportato:

    cscript EnableKB940248.vbs

Nota: Dopo aver eseguito questa procedura, solo la parte di query dell'URL può contenere caratteri estesi. La parte della query segue il punto interrogativo (?) nell'URL. La parte che precede il punto interrogativo nell'URL non può contenere caratteri estesi anche dopo l'utilizzo di questa risoluzione. Se si desidera rimuovere le modifiche apportate quando si esegue lo script nel passaggio 5, eseguire lo script seguente:

Const SE_VPS_GUID = "{143F5698-103B-12D4-FF34-1F34767DEabc}"Const SE_VPS_NAME = "CookieFilterDecodeUEncoding"Const SE_VPS_VALUE = FalseSub SetValue()' Create the root object.Dim root ' The FPCLib.FPC root objectroot = CreateObject("FPC.Root")'Declare the other objects that are needed.Dim array ' An FPCArray objectDim VendorSets ' An FPCVendorParametersSets collectionDim VendorSet ' An FPCVendorParametersSet object' Get references to the array object' and to the network rules collection.array = root.GetContainingArrayVendorSets = array.VendorParametersSetsOn Error Resume NextVendorSet = VendorSets.Item(SE_VPS_GUID)If Err.Number <> 0 ThenErr.Clear()' Add the itemVendorSet = VendorSets.Add(SE_VPS_GUID)CheckError()WScript.Echo("New VendorSet added... " & VendorSet.Name)ElseWScript.Echo("Existing VendorSet found... value- " & VendorSet.Value(SE_VPS_NAME))End IfIf VendorSet.Value(SE_VPS_NAME) <> SE_VPS_VALUE ThenErr.Clear()VendorSet.Value(SE_VPS_NAME) = SE_VPS_VALUEIf Err.Number <> 0 ThenCheckError()ElseVendorSets.Save(False, True)CheckError()If Err.Number = 0 ThenWScript.Echo("Done with " & SE_VPS_NAME & ", saved!")End IfEnd IfElseWScript.Echo("Done with " & SE_VPS_NAME & ", no change!")End IfEnd SubSub CheckError()If Err.Number <> 0 ThenWScript.Echo("An error occurred: 0x" & Hex(Err.Number) & " " & Err.Description)Err.Clear()End IfEnd SubSetValue Change to:[INSERT CORRECTION]Const SE_VPS_GUID = "{143F5698-103B-12D4-FF34-1F34767DEabc}"Const SE_VPS_NAME = "CookieFilterDecodeUEncoding"Const SE_VPS_VALUE = falseSub SetValue()' Create the root object.Dim root ' The FPCLib.FPC root objectSet root = CreateObject("FPC.Root")'Declare the other objects that are needed.Dim array ' An FPCArray objectDim VendorSets ' An FPCVendorParametersSets collectionDim VendorSet ' An FPCVendorParametersSet object' Get references to the array object' and to the network rules collection.Set array = root.GetContainingArraySet VendorSets = array.VendorParametersSetsOn Error Resume NextSet VendorSet = VendorSets.Item( SE_VPS_GUID )If Err.Number <> 0 ThenErr.Clear' Add the itemSet VendorSet = VendorSets.Add( SE_VPS_GUID )CheckErrorWScript.Echo "New VendorSet added... " & VendorSet.NameElseWScript.Echo "Existing VendorSet found... value- " & VendorSet.Value(SE_VPS_NAME)End Ifif VendorSet.Value(SE_VPS_NAME) <> SE_VPS_VALUE ThenErr.ClearVendorSet.Value(SE_VPS_NAME) = SE_VPS_VALUEIf Err.Number <> 0 ThenCheckErrorElseVendorSets.Save false, trueCheckErrorIf Err.Number = 0 ThenWScript.Echo "Done with " & SE_VPS_NAME & ", saved!"End IfEnd IfElseWScript.Echo "Done with " & SE_VPS_NAME & ", no change!"End IfEnd SubSub CheckError()If Err.Number <> 0 ThenWScript.Echo "An error occurred: 0x" & Hex(Err.Number) & " " & Err.DescriptionErr.ClearEnd IfEnd SubSetValue

Stato

Microsoft ha confermato che questo problema si verifica nei prodotti elencati nella sezione "Si applica a".

Serve aiuto?

Amplia le tue competenze
Esplora i corsi di formazione
Ottieni in anticipo le nuove caratteristiche
Partecipa a Microsoft Insider

Queste informazioni sono risultate utili?

Grazie per il feedback!

Grazie per il tuo feedback! Potrebbe essere utile metterti in contatto con uno dei nostri operatori del supporto di Office.

×