0

突然 (どうやら) Bootstrap (LESS) ソリューションを使用した完全に機能する MVC5 が実行を拒否しました。実行しようとすると、空白の画面が表示され、サイトが読み込まれません。

デバッグ モードで実行すると、約 90 秒後に次の例外でクラッシュします。

Exception thrown: 'System.AccessViolationException' in ClearScriptV8-32.dll

Additional information: Attempted to read or write protected memory. This is often an indication that other memory is corrupt.

ただし、を削除すると、ソリューションは正常に実行されます/bootstrap/less/grid.less

私が試したこと

V8エンジンをMsieに交換してみました。これはまた、それが問題であることを示唆してgrid.lessいます。特に、次の行を指しています。.make-grid(sm);

どこかで示唆されているのを見て、AVをオフにしてみました。違いはありませんでした。

私はそれをグーグルで検索しましたが、明らかに関連する唯一の情報はこのリンクでした。ReactConfig.csプーリングをオフにすることを提案していますが、ファイルがないため、これを行う方法がわかりません。または、それが私のソリューションに関連するかどうかもわかりません。

https://github.com/reactjs/React.NET/issues/102

私は私の深さから少し外れています。この問題を調査/デバッグする方法を誰かが助けたり提案したりできますか?

ありがとう!!


問題が見つかりました。ブートストラップ LESS ファイルが 2 回含まれていました。以下に答えてください。


V8 エンジンを使用したスタック トレース

  at Microsoft.ClearScript.V8.V8ContextProxyImpl.Execute(String gcDocumentName, String gcCode, Boolean evaluate, Boolean discard)
  at Microsoft.ClearScript.V8.V8ScriptEngine.<>c__DisplayClass1b.<Execute>b__19()
  at Microsoft.ClearScript.ScriptEngine.ScriptInvoke[T](Func`1 func)
  at Microsoft.ClearScript.V8.V8ScriptEngine.BaseScriptInvoke[T](Func`1 func)
  at Microsoft.ClearScript.V8.V8ScriptEngine.<>c__DisplayClass25`1.<ScriptInvoke>b__24()
  at Microsoft.ClearScript.V8.?A0x792c8756.LockCallback(Void* pvArg)
  at Microsoft.ClearScript.V8.V8ContextProxyImpl.InvokeWithLock(Action gcAction)
  at Microsoft.ClearScript.V8.V8ScriptEngine.ScriptInvoke[T](Func`1 func)
  at Microsoft.ClearScript.V8.V8ScriptEngine.Execute(String documentName, String code, Boolean evaluate, Boolean discard)
  at JavaScriptEngineSwitcher.V8.V8JsEngine.InnerEvaluate(String expression)
  at JavaScriptEngineSwitcher.V8.V8JsEngine.InnerEvaluate[T](String expression)
  at JavaScriptEngineSwitcher.Core.JsEngineBase.Evaluate[T](String expression)
  at BundleTransformer.Less.Internal.LessCompiler.Compile(String content, String path)
  at BundleTransformer.Less.Translators.LessTranslator.InnerTranslate(IAsset asset, LessCompiler lessCompiler, Boolean enableNativeMinification)
  at BundleTransformer.Less.Translators.LessTranslator.Translate(IList`1 assets)
  at BundleTransformer.Core.Transformers.TransformerBase.Translate(IList`1 assets, Boolean isDebugMode)
  at BundleTransformer.Core.Transformers.TransformerBase.Transform(IList`1 assets, BundleContext bundleContext, BundleResponse bundleResponse, VirtualPathProvider virtualPathProvider, Boolean isDebugMode)
  at BundleTransformer.Core.Transformers.TransformerBase.Process(BundleContext bundleContext, BundleResponse bundleResponse, Boolean isDebugMode)
  at BundleTransformer.Core.Transformers.TransformerBase.Process(BundleContext bundleContext, BundleResponse bundleResponse)
  at System.Web.Optimization.Bundle.ApplyTransforms(BundleContext context, String bundleContent, IEnumerable`1 bundleFiles)
  at System.Web.Optimization.Bundle.GenerateBundleResponse(BundleContext context)
  at System.Web.Optimization.Bundle.GetBundleResponse(BundleContext context)
  at System.Web.Optimization.BundleResolver.GetBundleContents(String virtualPath)
  at System.Web.Optimization.AssetManager.DeterminePathsToRender(IEnumerable`1 assets)
  at System.Web.Optimization.AssetManager.RenderExplicit(String tagFormat, String[] paths)
  at System.Web.Optimization.Styles.RenderFormat(String tagFormat, String[] paths)
  at System.Web.Optimization.Styles.Render(String[] paths)
  at ASP._Page_Views_Shared__Layout_cshtml.Execute() in C:\Users\MHL\OneDrive - FP\FpAccounting\FpAccounting\Views\Shared\_Layout.cshtml:line 7

Msie エンジンを使用したスタック トレース

    BundleTransformer.Core.Translators.AssetTranslationException was unhandled by user code
    HResult=-2146233088
    Message=During translation of LESS-code, readed from the file '/Content/Less/config.less', to CSS-code syntax error has occurred. 
  See more details:

  Error type: Syntax
  Message: Out of stack space
  File: /ThirdPartyPlugins/bootstrap/less/grid.less
  Line number: 66
  Column number: 3
  Source error:

  Line 65: @media (min-width: @screen-sm-min) {
  Line 66:   .make-grid(sm);
  -----------^
  Line 67: }


    Source=BundleTransformer.Less
    StackTrace:
         at BundleTransformer.Less.Translators.LessTranslator.InnerTranslate(IAsset asset, LessCompiler lessCompiler, Boolean enableNativeMinification)
         at BundleTransformer.Less.Translators.LessTranslator.Translate(IList`1 assets)
         at BundleTransformer.Core.Transformers.TransformerBase.Translate(IList`1 assets, Boolean isDebugMode)
         at BundleTransformer.Core.Transformers.TransformerBase.Transform(IList`1 assets, BundleContext bundleContext, BundleResponse bundleResponse, VirtualPathProvider virtualPathProvider, Boolean isDebugMode)
         at BundleTransformer.Core.Transformers.TransformerBase.Process(BundleContext bundleContext, BundleResponse bundleResponse, Boolean isDebugMode)
         at BundleTransformer.Core.Transformers.TransformerBase.Process(BundleContext bundleContext, BundleResponse bundleResponse)
         at System.Web.Optimization.Bundle.ApplyTransforms(BundleContext context, String bundleContent, IEnumerable`1 bundleFiles)
         at System.Web.Optimization.Bundle.GenerateBundleResponse(BundleContext context)
         at System.Web.Optimization.Bundle.GetBundleResponse(BundleContext context)
         at System.Web.Optimization.BundleResolver.GetBundleContents(String virtualPath)
         at System.Web.Optimization.AssetManager.DeterminePathsToRender(IEnumerable`1 assets)
         at System.Web.Optimization.AssetManager.RenderExplicit(String tagFormat, String[] paths)
         at System.Web.Optimization.Styles.RenderFormat(String tagFormat, String[] paths)
         at System.Web.Optimization.Styles.Render(String[] paths)
         at ASP._Page_Views_Shared__Layout_cshtml.Execute() in C:\Users\MHL\OneDrive - FP\FpAccounting\FpAccounting\Views\Shared\_Layout.cshtml:line 7
         at System.Web.WebPages.WebPageBase.ExecutePageHierarchy()
         at System.Web.Mvc.WebViewPage.ExecutePageHierarchy()
         at System.Web.WebPages.WebPageBase.ExecutePageHierarchy(WebPageContext pageContext, TextWriter writer, WebPageRenderingBase startPage)
         at System.Web.WebPages.WebPageBase.<>c__DisplayClass3.<RenderPageCore>b__2(TextWriter writer)
         at System.Web.WebPages.HelperResult.WriteTo(TextWriter writer)
         at System.Web.WebPages.WebPageBase.Write(HelperResult result)
         at System.Web.WebPages.WebPageBase.RenderSurrounding(String partialViewName, Action`1 body)
         at System.Web.WebPages.WebPageBase.PopContext()
         at System.Web.WebPages.WebPageBase.ExecutePageHierarchy(WebPageContext pageContext, TextWriter writer, WebPageRenderingBase startPage)
         at System.Web.Mvc.RazorView.RenderView(ViewContext viewContext, TextWriter writer, Object instance)
         at System.Web.Mvc.BuildManagerCompiledView.Render(ViewContext viewContext, TextWriter writer)
         at System.Web.Mvc.ViewResultBase.ExecuteResult(ControllerContext context)
         at System.Web.Mvc.ControllerActionInvoker.InvokeActionResult(ControllerContext controllerContext, ActionResult actionResult)
         at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilterRecursive(IList`1 filters, Int32 filterIndex, ResultExecutingContext preContext, ControllerContext controllerContext, ActionResult actionResult)
         at System.Web.Mvc.ControllerActionInvoker.InvokeActionResultFilterRecursive(IList`1 filters, Int32 filterIndex, ResultExecutingContext preContext, ControllerContext controllerContext, ActionResult actionResult)
    InnerException: 

ブートストラップ grid.less

  //
  // Grid system
  // --------------------------------------------------


  // Container widths
  //
  // Set the container width, and override it for fixed navbars in media queries.

  .container {
    .container-fixed();

    @media (min-width: @screen-sm-min) {
      width: @container-sm;
    }
    @media (min-width: @screen-md-min) {
      width: @container-md;
    }
    @media (min-width: @screen-lg-min) {
      width: @container-lg;
    }
  }


  // Fluid container
  //
  // Utilizes the mixin meant for fixed width containers, but without any defined
  // width for fluid, full width layouts.

  .container-fluid {
    .container-fixed();
  }


  // Row
  //
  // Rows contain and clear the floats of your columns.

  .row {
    .make-row();
  }


  // Columns
  //
  // Common styles for small and large grid columns

  .make-grid-columns();


  // Extra small grid
  //
  // Columns, offsets, pushes, and pulls for extra small devices like
  // smartphones.

  .make-grid(xs);


  // Small grid
  //
  // Columns, offsets, pushes, and pulls for the small device range, from phones
  // to tablets.

  @media (min-width: @screen-sm-min) {
    .make-grid(sm);
  }


  // Medium grid
  //
  // Columns, offsets, pushes, and pulls for the desktop device range.

  @media (min-width: @screen-md-min) {
    .make-grid(md);
  }


  // Large grid
  //
  // Columns, offsets, pushes, and pulls for the large desktop device range.

  @media (min-width: @screen-lg-min) {
    .make-grid(lg);
  }

JsEngineSwitcherConfig.cs

public class JsEngineSwitcherConfig
{
    public static void Configure(JsEngineSwitcher engineSwitcher)
    {
        engineSwitcher.EngineFactories
            .AddV8();
        engineSwitcher.DefaultEngineName = V8JsEngine.EngineName;
    }
}

... Global.asax で呼び出されます

JsEngineSwitcherConfig.Configure(JsEngineSwitcher.Instance);

そして Web.config で

 <bundleTransformer xmlns="http://tempuri.org/BundleTransformer.Configuration.xsd">
   <less useNativeMinification="false" ieCompat="true" strictMath="false" strictUnits="false" dumpLineNumbers="None">
     <jsEngine name="V8JsEngine" />
   </less>
   <core>
     <css>
       <translators>
         <add name="NullTranslator" type="BundleTransformer.Core.Translators.NullTranslator, BundleTransformer.Core" enabled="false" />

       <add name="LessTranslator" type="BundleTransformer.Less.Translators.LessTranslator, BundleTransformer.Less" /></translators>
       <postProcessors>
         <add name="UrlRewritingCssPostProcessor" type="BundleTransformer.Core.PostProcessors.UrlRewritingCssPostProcessor, BundleTransformer.Core" useInDebugMode="false" />
       </postProcessors>
       <minifiers>
         <add name="NullMinifier" type="BundleTransformer.Core.Minifiers.NullMinifier, BundleTransformer.Core" />
       </minifiers>
       <fileExtensions>
         <add fileExtension=".css" assetTypeCode="Css" />

       <add fileExtension=".less" assetTypeCode="Less" /></fileExtensions>
     </css>
     <js>
       <translators>
         <add name="NullTranslator" type="BundleTransformer.Core.Translators.NullTranslator, BundleTransformer.Core" enabled="false" />
       </translators>
       <minifiers>
         <add name="NullMinifier" type="BundleTransformer.Core.Minifiers.NullMinifier, BundleTransformer.Core" />
       </minifiers>
       <fileExtensions>
         <add fileExtension=".js" assetTypeCode="JavaScript" />
       </fileExtensions>
     </js>
   </core>
 </bundleTransformer>
4

1 に答える 1