CefSharp - 获取AJAX请求的结果

时间:2016-05-10 14:20:44

标签: javascript c# jquery ajax cefsharp

我是CefSharps Chromium浏览器的新手,很难弄清楚如何获取jquery ajax请求的结果。

我的第一次尝试是将我的AJAX请求传递给EvaluateScriptAsync。实际上脚本有效。它完全符合我的要求,但我没有得到任何结果/状态代码,因为我的Cef-Task不会等到AJAX完成它的工作。

这是一个例子(只是一个示例代码):

var tasks = pdBrowser.EvaluateScriptAsync(@"
    (function(){
        $.ajax({
            type: ""POST"",
            dataType: ""json"",
            cache: false,
            url: ""_resources/php/ajaxRequests.php"",
            async: false,
            data: {
                action: ""insertCrossPlatform"",
                type: """",
                values: JSON.stringify(""foo bar"")
            },
            success: function(response) {
                if (typeof response === 'string' && response.substring(0, 5) == ""ERROR"")
                {
                    return response;
                }
                    else
                {
                    //pageReload();
                    return ""OK"";
                }
            },
            error: function(xhr, textStatus, errorThrown) {
                return errorThrown + ""\n"" + xhr.responseText;
            },
            complete: function() {
                return ""COMPLETE"";
            }
        });
    })();", null);

tasks.ContinueWith(t =>
{
     if (!t.IsFaulted)
    {
        var response = t.Result;
        if (response.Success)
        {
            if (response.Result != null)
            {
                MessageBox.Show(response.Result.ToString());
            }
        }
        else
        {
            MessageBox.Show(response.Message, "Ein Fehler ist aufgetreten", MessageBoxButtons.OK, MessageBoxIcon.Exclamation);
        }
    }
}, TaskScheduler.Default);

之后我读到有一个SchemeHandler,但我没有正确理解如何实现它。任何人都可以帮助我吗?

提前致谢。

2 个答案:

答案 0 :(得分:1)

首先SchemeHandler不太适合这种情况,通常在提供回复时实施SchemeHandler

大多数人选择绑定一个对象,并在他们希望与父应用程序通信时调用绑定对象上的方法。有关示例,请参阅FAQhttps://github.com/cefsharp/CefSharp/wiki/Frequently-asked-questions#3-how-do-you-expose-a-net-class-to-javascript

使用49.0.0,您可以实现ResponseFilter以获取对底层响应缓冲区的访问权限,它很复杂且没有详细记录,因此如果您不方便通过引用C++代码进行挖掘,那么此选项不适合你。这是参考https://github.com/cefsharp/CefSharp/blob/cefsharp/49/CefSharp.Example/Filters/PassThruResponseFilter.cs#L17

答案 1 :(得分:-1)

我所做的是通过javascript在页面上创建一个元素,其ID是ajax调用的响应。因此,例如,当您进行ajax调用时,为ajax调用分配ID。

当ajax调用返回时,在页面上写一个元素,其中包含预先指定的id和回调信息。然后你可以使用cefsharp从页面中读取元素内容,这将是你的回调信息。

var myDivElement =document.getElementById('textareaInfo');

if( myDivElement === null)
{
var input = document.createElement('textarea'); 
input.id = "textareaInfo";
input.value = "Test"
input.rows="4";
input.cols="50";
input.style="height:100%;width:900px;"

var dom = document.getElementsByClassName("page-body")[0];
dom.insertAdjacentElement('afterbegin', input)
}
  

然后用ajax

var root = 'https://jsonplaceholder.typicode.com';

var _holder = callbackObj;

callbackObj.showMessage(""ajax"");

$.ajax({

  url: root + '/posts/1',
 contentType: 'application/json; charset=utf-8',
  method: 'GET',
complete: function(data){

},
 success: function(response) {

     $(#'textareaInfo').value(response);                
                        }
}).then(function(data) {
   callbackObj.showMessage(data);
});
  

然后在c#

中阅读来自cefsharp的texarea

chromeBrowser.GetMainFrame()。EvaluateScriptAsync(函数()... $(textareaInfo)。价值)。结果