Winforms с использованием CefSharp дает сбой, говоря Accessviolation - PullRequest
0 голосов
/ 04 июня 2019

У меня есть приложение WinForms, которое будет работать часами.Это начало сбой через 3-4 часа с перерывами.Он использует CefSharp.Журналы событий показывают, что ошибка связана с CEFSharp, но я не могу идти дальше ... Любая помощь будет принята с благодарностью

Machine: Windows 7 Sp1
VC++ runtime installed
.NET framework 4.7
The crash dump shows below information:
Exception: the thread tried to read from or write to a virtual 
address for which it does not have the appropriate access.
Tried debugging crash dump, but not useful

Журналы событий ниже:

   - <Event xmlns="http://schemas.microsoft.com/win/2004/08/events/event">
   - <System>
     <Provider Name=".NET Runtime" /> 
     <EventID Qualifiers="0">1026</EventID> 
     <Level>2</Level> 
       <Task>0</Task> 
     <Keywords>0x80000000000000</Keywords> 
      <TimeCreated SystemTime="2019-05-31T14:38:54.000000000Z" /> 
     <EventRecordID>920</EventRecordID> 
      <Channel>Application</Channel> 
      <Security /> 
      </System>
    - <EventData>
      <Data>Application: Client.exe Framework Version: v4.0.30319 
         Description: The process was terminated due to an unhandled 
        exception. Exception Info: System.AccessViolationException at 
        CefSharp.Internals.MCefRefPtr<CefPostData>.op_Assign(CefPostData*) at 
        CefSharp.Internals.CefPostDataWrapper.~CefPostDataWrapper() at 
         CefSharp.Internals.CefPostDataWrapper.Dispose(Boolean) at 
               CefSharp.Internals.CefPostDataWrapper.Dispose() at 
              Client.AsmxRequestHandler+

ProcessRequestAsync (IRequestзапрос, обратный вызов ICallback) {m_callback = обратный вызов;

        Task.Run(() =>
        {
            using (callback)
            {
                try
                {
                    using (var postData = request.PostData)
                    {
                        if (postData.Elements != null)
                        {
                            var elements = postData.Elements;
                            var charSet = request.GetCharSet();
                            var element = elements[0];
                            var elementBodyString = string.Empty;
                            foreach (var elemt in elements)
                            {
                                if (element.Type == PostDataElementType.Bytes)
                                {
                                    elementBodyString += elemt.GetBody(charSet);
                                }
                            }

                            if (element.Type == PostDataElementType.Bytes)
                            {
                                XmlSerializer mySerializerObj = new XmlSerializer(typeof(AsmxWrapperClasses.Envelope));

                                var mySoapRequest = (AsmxWrapperClasses.Envelope)mySerializerObj.Deserialize(GenerateStreamFromString(elementBodyString));
                                var requestBody = mySoapRequest.Body;

                                try
                                {
                                    var myResult = ProcessRequestBody(requestBody);

                                    var stream = GenerateStreamFromString(myResult);
                                    stream.Position = 0;
                                    ResponseLength = stream.Length;
                                    MimeType = MimeTypeMap.GetMimeType(Path.GetExtension(".asmx"));
                                    StatusCode = (int)HttpStatusCode.OK;
                                    Stream = stream;

                                    callback.Continue();
                                }
                                catch (ArgumentException ex)
                                {
                                    if (ex.Message == "requestBody invalid")
                                        throw new Exception(elementBodyString);
                                    throw;
                                }

                            }
                        }
                    }
                }
                catch (Exception ex)
                {
                    Debug.WriteLine(ex);
                    CLogger.GetInstance().LogError(ex.Message);
                }
            }
        });

        return true;
    }
...