Xilium.CefGlue利用XHR实现Js调用c#方法

时间:2022-12-15 10:03:59

防外链

博客园原文地址在这里http://www.cnblogs.com/shen6041/p/3442499.html

Xilium CefGlue是个不错的cef扩展工程,托管地址在这里 https://bitbucket.org/xilium/xilium.cefglue/wiki/Home

当然它还有很多工作要做,这里介绍一下怎样利用XHR实现Js调用c#方法。代码已经在官方Demo里,只是没有中文资料,英文资料也几乎没有,这里只是把它挖出来讲一下,本人毫无技术含量。ps:感谢热心的@dmitry.azaraev邮件耐心回复。

本文参考自 http://www.wuleba.com/23614.html,感谢@flydoos给我很多启发。

另外园子里也有介绍入门教程:http://www.cnblogs.com/liulun/archive/2013/03/18/2874276.html,建议先阅读该系列教程。

什么是XHR

XMLHttpRequest (XHR) is an API available to web browser scripting languages such as JavaScript. It is used to send HTTP or HTTPSrequests to a web server and load the server response data back into the script.[1] Development versions of all major browsers support URI schemes beyond http: and https:, in particular, blob: URLs are supported.[2]

在这里,XHR可以向CefGlue浏览器发送请求,并接收回复,简单的字符串即可通过Post传递,如果是复杂对象,可以使用Json转换后传递。

CefGlue提供的API

RegisterSchemeHandlerFactory(string schemeName, string domainName, CefSchemeHandlerFactory factory)

该方法位于CefRuntime,在启动Initialize后使用。其向浏览器注册一个Scheme处理工厂。

三个参数:

schemeName:scheme名;

domainName:使用域 的名称,这一个参数比较重要,在js中我们需要向这个地址发送Post请求,可以随便填,比如 "testdomain",那么在js中请求的地址是 "http://testdomain/";

factory:处理工厂,需要来装配一个处理handle。

C#端需要做的两项工作

1.新建一个类DumpRequestResourceHandler,继承自CefResourceHandler,有六个函数需要我们继承,这里只用到前面三个。

protected override bool ProcessRequest(CefRequest request, CefCallback callback)
{
//
return true;
} protected override void GetResponseHeaders(CefResponse response, out long responseLength, out string redirectUrl)
{
//
responseLength = -;
redirectUrl = null;
} protected override bool ReadResponse(Stream response, int bytesToRead, out int bytesRead, CefCallback callback)
{
//
bytesRead = ;
return false; } protected override bool CanGetCookie(CefCookie cookie)
{
return false;
} protected override bool CanSetCookie(CefCookie cookie)
{
return false;
} protected override void Cancel()
{
}

2.新建一个类DemoAppSchemeHandlerFactory,继承自CefSchemeHandlerFactory
这个就是我们需要在注册时用到的工厂,继承他的Creat函数,返回我们上面建的DumpRequestResourceHandler实例即可。

        protected override CefResourceHandler Create(CefBrowser browser, CefFrame frame, string schemeName, CefRequest request)
{
return new DumpRequestResourceHandler();
}

Js端需要做的工作
js端需要做的就是创建一个XmlHttpRequest,向之前注册的地址发请求即可,代码在园子里很多,随便搜搜就能找到。

<script type="text/javascript">
function CreateXmlHttpRequest() {
var xmlHttp = null;
if (window.XMLHttpRequest) {
// For Mozilla, Safari, ...
xmlHttp = new XMLHttpRequest();
}
else if (window.ActiveXObject) {
// For Internet Explorer
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
return xmlHttp;
}
function testPost() {
var xmlHttp = CreateXmlHttpRequest();
var para = "id=testid&name=testname";
xmlHttp.open("POST", "http://testdomain/", false);
xmlHttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
xmlHttp.send(para);
var result = xmlHttp.status;
if (xmlHttp.readyState == ) {
if (result == ) {
var response = xmlHttp.responseText;
alert(response);
}
}
}
</script>

这里的js只是举个栗子,你也可以用异步的请求之类的,不要在意这些细节。

如何接收Post数据

回到DumpRequestResourceHandler 的ProcessRequest方法,post过来的数据就在request.PostData里,GetElements()以后把字节数组转成字符串即可。

怎么返回数据给Js

在DumpRequestResourceHandler的GetResponseHeaders方法里,你需要回复一个接收成功的状态:

response.MimeType = "text/html";
response.Status = ;
response.StatusText = "OK, hello from handler!";

并写一些头信息:

            var headers = new NameValueCollection(StringComparer.InvariantCultureIgnoreCase);
headers.Add("Cache-Control", "private");
headers.Add("Access-Control-Allow-Origin","*");
response.SetHeaderMap(headers);

注意这一句代码:headers.Add("Access-Control-Allow-Origin","*"); 因为跨域的问题,如果你的html在本地,XHR的返回永远都是0并没有数据。这里是允许所有的跨域访问,存在安全问题暂时不表。

你可以在这里找到更多资料:

http://*.com/questions/15977151/loading-local-content-through-xhr-in-a-chrome-packaged-app

http://blog.csdn.net/hfahe/article/details/7730944

在ReadResponse方法里把数据写回去:

response.Write(responseData, pos, bytesToRead);

是不是跑题了?一直都没讲怎么调用c#方法啊?你特么是在逗我吗?
......

我是这样做的,在js的post数据里带参数,比如我要调用的c#方法是A类中的test(string msg);

我的post参数这样传:

var para = "method=test&msg=testtext";

ProcessRequest拿到参数以后就知道了函数的名字和参数,将A类中的test方法反射出来执行,如需要返回值,参考上面的方法即可。

这样做存在一些问题,比如函数无法重载、js和c#类型转换之类的。

我这边项目用到的基本公开给js的函数都很明确,没有重载;另外有复杂对象,也能用json来解决。暂时绕开了这些问题,当然也不是很难解决。

官方的代码实例可以在这里找到:

Xilium.CefGlue.Demo.DemoApp  78行,注册scheme

Xilium.CefGlue.Demo的SchemeHandler文件夹下的DemoAppSchemeHandlerFactory、DumpRequestResourceHandler两个类。

如果有不明白的地方,可以慢慢看代码。

感兴趣的,可以加入:WebKit/Blink 内核浏览器开发 QQ交流群:244840771

Xilium.CefGlue利用XHR实现Js调用c#方法的更多相关文章

  1. JS调用Silverlight方法拾遗

    在最近做的物联网项目中,需要利用封装过的Silverlight刻度控件显示温度,湿度,二氧化碳浓度等值.由于最新的数据是通过js ajax获取的,所以需要把这些数据传递给silverlight显示,这 ...

  2. JS调用OC方法并传值,OC调用JS方法并传值&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;&sol;zz

     iOS开发-基于原生JS与OC方法互相调用并传值(附HTML代码)     最近项目里面有有个商品活动界面,要与web端传值,将用户在网页点击的商品id 传给客户端,也就是js交互,其实再说明白一点 ...

  3. &lbrack;iOS Hybrid实践:UIWebView中Html中用JS调用OC方法,OC执行JS代码&rsqb;

    原理: 1.JS调用OC 每次webview执行跳转时都会被iOS给拦截,执行下面函数获得系统允许. 因此可以根据跳转信息转给系统,执行相应功能,比如打开相册等. // 网页中的每一个请求都会被触发 ...

  4. UIWebView中Html中用JS调用OC方法及OC执行JS代码

    HTML代码: <html> <head> <title>HTML中用JS调用OC方法</title> <meta http-equiv=&quo ...

  5. js调用后台方法(如果你能容忍执行的后台方法变成一个常量)

    最近一直在做一个电话拨号的系统,系统不大,但是做的时间有点长了.其中用到了一个技术:js调用后台方法.解决这个问题花了不少时间,现如今仍然还有些不明白的地方,今天跟大家分享一下.真正明白的同学欢迎指正 ...

  6. c&num; js调用AjaxPro方法出错解析

    公司的项目的框架中有一部分用到了AjaxPro这个方法,看到这个方法的我一脸懵逼,老老实实去百度了一下. AjaxPro是.NET平台下的一个回调式AJAX框架,使用简单,功能强大.顾名思义ajax, ...

  7. 在WebBrowser控件使用js调用C&num;方法

    有时我们需要在WebBrowser控件中嵌入了网页,然后通过html页面调用后台方法,如何实现呢?其实很简单,主要有三步: 在被调用方法所属的类上加上[ComVisible(true)]标签,意思就是 ...

  8. JS调用App方法及App调用JS方法

    做App内嵌H5项目时,经常会遇到js与App的交互,最普遍的就是方法的互相调用,那么如何实现方法的互相调用呢? 写在前面: 如果只是小项目且后期扩大的可能性不大的时候,可以忽略,可如果是长期项目的话 ...

  9. Xilium&period;CefGlue怎么使用Js调用C&num;方法

    第1篇:.NET多种WebKit内核/Blink内核浏览器初步测评报告http://www.wuleba.com/?p=23590 第2篇:Xilium CefGlue 关于 CLR Object 与 ...

随机推荐

  1. &lbrack;源码&rsqb;DataIOStream 数据流 处理基本数据类型的流

    纵骑横飞  章仕烜   首先我们来看一下 DataOutputStream   /**  * A data output stream lets an application write primit ...

  2. paip&period;提升性能----数据库连接池以及线程池以及对象池

    paip.提升性能----数据库连接池以及线程池以及对象池 目录:数据库连接池c3po,线程池ExecutorService:Jakartacommons-pool对象池 作者Attilax  艾龙, ...

  3. 如何开启PostGreSQL的远程访问端口?

    用以下办法即可: postgresql默认情况下,远程访问不能成功,如果需要允许远程访问,需要修改两个配置文件,说明如下: 1.postgresql.conf 将该文件中的listen_address ...

  4. 关于qquu8 的主页修改

    1) 找到 这个文件夹 C:\Users\lidu\AppData\Roaming\Microsoft\Internet Explorer\Quick Launch\User Pinned\TaskB ...

  5. 2016-2017 ACM-ICPC&comma; NEERC&comma; Southern Subregional Contest &lpar;Online Mirror&comma; ACM-ICPC Rules&comma; Teams Preferred&rpar; J dp 背包

    J. Bottles time limit per test 2 seconds memory limit per test 512 megabytes input standard input ou ...

  6. 堆排序 C&plus;&plus;

    1 堆排序拥有插入排序的优点 (是一种原地排序算法只需要存储常数个元素在输入数组以外 即省空间), 同时拥有合并排序算法的复杂度 nlgn,逼格有点高 2 堆数据结构 是一个数组对象,可以被视为一颗完 ...

  7. Is the Information Reliable&quest;(差分约束)

    Description The galaxy war between the Empire Draco and the Commonwealth of Zibu broke out 3 years a ...

  8. 全数字锁相环(DPLL)的原理简介以及verilog设计代码

    随着数字电路技术的发展,数字锁相环在调制解调.频率合成.FM 立体声解码.彩色副载波同步.图象处理等各个方面得到了广泛的应用.数字锁相环不仅吸收了数字电路可靠性高.体积小.价格低等优点,还解决了模拟锁 ...

  9. 第一百二十九节,JavaScript,理解JavaScript库

    JavaScript,理解JavaScript库 学习要点: 1.项目介绍 2.理解JavaScript库 3.创建基础库 从本章,我们来用之前的基础知识来写一个项目,用以巩固之前所学.那么,每个项目 ...

  10. Pomelo聊天室框架

    聊天室是验证服务器最典型的例子,Pomelo的运行架构: 在这个架构里,前端服务器也就是connector专门负责承载连接, 后端的聊天服务器则是处理具体逻辑的地方. 这样扩展的运行架构具有如下优势: ...