2

デバッグの助けが必要な win32 例外が発生しています。カスタム Web パーツを含む SharePoint ページがあり、そのページを参照すると、次のメッセージが表示されます。

In w3wp.dmp the assembly instruction at ntdll!RtlReportCriticalFailure+62 in 
C:\Windows\System32\ntdll.dll from Microsoft Corporation has caused an unknown
exception (0xc0000374) on thread 43

Unhandled exception at 0xHEX in w3wp.exe: 0xc0000374: 
A heap has been corrupted

この問題のデバッグをどこから始めればよいのかよくわかりません。また、インターネットを検索してもほとんど結果が得られませんでした。

DMP ファイルを保存し、分析のためにデバッグ診断ツールにロードしました。どの部分が最も重要なのか分からないので、誰かが私が投稿すべきセクションを教えてくれれば、投稿します.

私が問題だと思う場所は次のとおりです。

問題が発生している可能性のある場所を絞り込みました。これらのメソッドを呼び出さないと、エラーは発生しません。TermStore へのアクセス方法に何か問題がありますか?

    private void GetTerms()
    {
        using (SPSite site = new SPSite(PhaseListUrl.Value))
        {
            var session = new TaxonomySession(site);
            if (session.TermStores == null || session.TermStores.Count == 0) return;

            OfficeDropdown.Items.Clear();
            OfficeDropdown.Items.Add("");

            var termStore = session
                .TermStores
                .FirstOrDefault(ts => ts.Groups.Any(g => g.Name == TaxonomyName.Value));
            try
            {
                var group = termStore.Groups[TaxonomyName.Value];
                foreach (var ts in group.TermSets)
                {
                    if (!ts.IsAvailableForTagging) continue;

                    AddTerms(site, termStore, ts.Id, ts.Terms);
                }
            }
            catch (NullReferenceException) { OfficeDropdown.Items.Add("ERROR: Check your Org Term Store Name"); }
            catch (ArgumentOutOfRangeException) { OfficeDropdown.Items.Add("ERROR: Check your Org Term Store Name"); }
        }
    }

    private void AddTerms(SPSite site, TermStore termStore, Guid tsId, TermCollection coll)
    {
        foreach (var t in coll)
        {
            if (t.IsAvailableForTagging)
            {
                var wssIds = TaxonomyField.GetWssIdsOfTerm(site, termStore.Id, tsId, t.Id, true, 1000);

                if (wssIds.Length != 0)
                {
                    var id = wssIds[0];
                    var validatedString = string.Format("{0};#{1}{2}{3}", id, t.Name, TaxonomyField.TaxonomyGuidLabelDelimiter, t.Id);
                    OfficeDropdown.Items.Add(new ListItem(t.Name, validatedString));
                }
                else
                {
                    int id = -1;
                    var value = new TaxonomyFieldValue(SPContext.Current.Web.AvailableFields[new Guid("{a64c1f69-c0d6-421a-8c8a-9ef8f459d7a2}")]);
                    value.TermGuid = t.Id.ToString();

                    var dummy = value.ValidatedString;
                    if (dummy != null)
                        id = value.WssId;

                    var validatedString = string.Format("{0};#{1}{2}{3}", id, t.Name, TaxonomyField.TaxonomyGuidLabelDelimiter, t.Id);
                    OfficeDropdown.Items.Add(new ListItem(t.Name, validatedString));
                }
            }
            AddTerms(site, termStore, tsId, t.Terms);
        }
    }

アップデート:

バグはにありましたTaxonomyField。用語クロス サイト コレクションにアクセスしていましたが、ID が生成されていませんでした。また、TermStoreID が同じクロス サイト コレクションではないことに注意してください (そして、どこから呼び出しているか、どこに呼び出しているかを把握してください!)

4

1 に答える 1

0

ここにいくつかの提案があります。

  1. ログ ビューアーを起動してULSログを調べます。ページにアクセスしてそのエラーが発生した場合は、そこにログが記録されているはずです。

  2. Web フロントエンド サーバーのアプリケーション イベント ログを確認します。

  3. W3P.exeプロセスへのアタッチとソリューションのデバッグも試しましたか? (もちろん、本番環境ではないと仮定します)。

于 2013-02-15T02:12:22.583 に答える