現象
次のような状況で問題が発生します。
-
Certificate Services Web Enrollment ロール サービスは、Windows Server 2008 R2 ベースのサーバーにインストールされます。
-
インターネット エクスプローラー 10 以降のバージョンを実行しているクライアント コンピューターがあります。
-
Windows Server 2008 R2 ベースのサーバーでホストされている証明書サービス Web 登録ページにアクセスしようとするとします。
このシナリオでは、インターネット エクスプローラーで次のエラーが発生します。
この Web ブラウザーでは、証明書要求の生成はサポートされていません
原因
ブラウザーのバージョン チェック、インターネット エクスプローラー バージョンが "IE 1" と誤って識別されます。
回避策
この問題でサポートされている回避策は次のとおりです。
-
インターネット エクスプローラーで互換性ビューを構成します。
-
Web 登録ページの機能をWindows Server 2012に移動します。
-
Certsbrt.inc ファイルを変更します。44 行目から 70 行目を次の内容に置き換えます。 Certsbrt.inc は次のフォルダーにあります。
%WINDIR%\system32\certsrv\en-us
'' If there is no '.' in the UserAgent string, this will return the next character if any' as the version number. ' We extract the string until a '.' and then convert it' into integer. If -1 is returned from this function then it isn't MSIE 'Function GetInternetExplorerVersionNumber(sHttpUserAgent) Dim nMSIEGetInternetExplorerVersionNumber = -1 nMSIE = InStr(sHttpUserAgent, "MSIE") If 0 <> nMSIE Then numChar = InStr(Mid(sHttpUserAgent, nMSIE + 5), ".") - 1 If -1 = numChar Then ' no '.' in the string numChar = 1 End If If nMSIE + 5 + numChar - 1 <= Len(sHttpUserAgent) Then GetInternetExplorerVersionNumber = CInt(Mid(sHttpUserAgent, nMSIE + 5, numChar)) End If End IfEnd Function'' We define a Old MSIE based browser' if it has the string MSIE that is followed by a version number that is less than 4' NOTE:' IsOldMSIE = False does not imply MSIE >= 4.'' i.e. Not IsOldMSIE("abc") = True' Not IsOldMSIE("MSIE") = True'Function IsOldMSIE(sHttpUserAgent) Dim nMSIE Dim sMSIEVersion IsOldMSIE = False nMSIE = InStr(sHttpUserAgent, "MSIE") If nMSIE <> 0 AND (nMSIE+5 < Len(sHttpUserAgent)) Then nVersion = GetInternetExplorerVersionNumber(sHttpUserAgent) If -1 <> nVersion Then IsOldMSIE = nVersion < NEW_MSIE_VERSION End If End IfEnd Function
詳細情報
Windows Server 2008 R2 ベースのサーバー上の変更されていない Certsbrt.inc ファイルの 44 行目から 70 行目は次のとおりです。 これらは、置き換えられる行です。
'' We define a Old MSIE based browser' if it has the string MSIE that is followed by a version number that is less than 4' NOTE:' IsOldMSIE = False does not imply MSIE >= 4.'' i.e. Not IsOldMSIE("abc") = True' Not IsOldMSIE("MSIE") = True'Function IsOldMSIE(sHttpUserAgent) Dim nMSIE Dim sMSIEVersion nMSIE = InStr(sHttpUserAgent, "MSIE") If nMSIE=0 Then IsOldMSIE = False ElseIf nMSIE+5 < Len(sHttpUserAgent) Then sMSIEVersion = Mid(sHttpUserAgent, nMSIE+5, 1) IsOldMSIE = CInt(sMSIEVersion) < NEW_MSIE_VERSION Else IsOldMSIE = False End IfEnd Function