Príznaky
Keď používateľ otvorí SharePoint webovej lokality, ktoré sú Publikované v Microsoft Internet Security and Acceleration (ISA) Server 2006, ISA Server 2006 SP1 alebo Windows Essential Business Server 2008, používateľ môže zobraziť nasledujúce chybové hlásenia: chyba Správa 1
HTTP 401 neoprávnené
Chybové hlásenie 2
HTTP 500 server odmietol zadané Uniform Resource Locator (URL). Obráťte sa na správcu servera.
Tento problém sa vyskytuje, ak sú splnené nasledujúce podmienky:
-
V webový prijímač, ktorý používa pravidlo pre publikovanie webovej lokality SharePoint je nakonfigurovaná HTML Form Authentication.
-
Webový klient odošle požiadavku POST webovej lokality SharePoint.
-
URL POST požiadavka obsahuje rozšírené znaky. Adresa URL obsahuje napríklad à, é a è.
Príčina
Tento problém sa vyskytuje, pretože ISA Server alebo Windows Essential Business Server 2008 nemôže analyzovať URL obsahuje rozšírené znaky. V takom prípade ISA Server alebo Windows Essential Business Server 2008 odmieta požiadavku POST, ktoré klient odošle.
Riešenie
Ak chcete vyriešiť tento problém, postupujte nasledovne:
-
Použite rýchlu opravu popísanú v článku databázy Microsoft Knowledge Base 940250. Ďalšie informácie získate po kliknutí na nasledovné číslo článku publikovaného v databáze Microsoft Knowledge Base:
940250 Popis balík s rýchlou ISA Server 2006: 16. júla 2007
-
Skopírujte nasledujúci skript do programu Poznámkový blok:Poznámka tento problém ISA Server 2006, použite nasledujúci skript. Nemusíte použiť rýchlu opravu v tomto článku pre ISA Server 2006 SP1, ale budete musieť použiť skript.
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
-
Súbor uložte ako súbor skriptu Microsoft Visual Basic pomocou prípony súboru .vbs. Napríklad súbor uložiť nasledujúci názov:
EnableKB940248.vbs
-
Do príkazového riadka, prejdite do umiestnenia, kam ste uložili súbor EnableKB940248.vbs.
-
Spustite nasledujúci príkaz:
cscript EnableKB940248.vbs
Poznámka: Po vykonaní týchto krokov, iba časť dotazu adresy URL môže obsahovať znaky s diakritikou. Časť dotazu nasleduje otáznik (?) v adrese URL. Časť, ktorá predchádza otáznik URL nemôže obsahovať znaky s diakritikou, aj po použití tohto riešenia. Ak chcete odstrániť zmeny vykonané po spustení skriptu v kroku 5, spustite nasledujúci skript:
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
Stav
Spoločnosť Microsoft potvrdzuje, že ide o problém v produktoch spoločnosti Microsoft, ktoré sú uvedené v tomto článku v časti Informácie v tomto článku sa týkajú nasledujúcich produktov.