python3调用微软js引擎ChakraCore
有关ChakraCore介绍请移步:https://github.com/Microsoft/ChakraCore
使用案例GitHub源码:https://github.com/pyAppman/ChakraCore
本文主要讲下python调用ChakraCore.dll
参考文献有:https://xz.aliyun.com/t/2450 以及 https://bbs.125.la/forum.php?mod=viewthread&tid=14495171&highlight=ChakraCore
python是解释性语言,网上能搜到的基本都是C、C#、C++、易语言的ChakraCore使用,并没有python使用方法,参考了上面大佬们的相关介绍使用以及官方文档,写了如下可以成功调用的python例子。之所以写这个是因为:第一,暂目前python用于执行js的工具有node,pyv8,js2py,windows系统下的com组件,node性能不好,v8不够全安装费劲不说,对python2更友好,js2py运行小js还可以,大了就不行了,com不够全面比不上node内置的js函数,也不能跨平台,ChakraCore综合了node的全面跟v8的性能,还能跨平台。第二、网上也有不少关于ChakraCore的文章,但是没有python的,而易语言,C,C++这些并不是解释性语言,很多方面跟python不一样。第三、自己能力有限,过程中爬了很多坑,好似盲人过河,也算是想给其他有兴趣的人一点帮助
一、准备工具
python解释器,本人用的32位python3.6.x,其他版本也可以,但是务必用32位,跟dll有关原因不多做说明。
封装的 ChakraCore.dll文件,源文件网上有,可以自行搜索下载,也可以https://github.com/pyAppman/ChakraCore上下载。
二、ChakraCore的部分方法(按顺序执行)
1、JsCreateRuntime(文档:https://github.com/microsoft/ChakraCore/wiki/JsCreateRuntime)
// 创建完整的JavaScript执行环境
2、JsCreateContext(文档:https://github.com/microsoft/ChakraCore/wiki/JsCreateContext)
// 创建一个执行js的上下文环境
3、JsSetCurrentContext(文档:https://github.com/microsoft/ChakraCore/wiki/JsSetCurrentContext)
// 表示一个拥有和别的execution contexts不同的JavaScript全局对象JavaScript的执行环境。
4、JsRunScript(文档:https://github.com/microsoft/ChakraCore/wiki/JsRunScript)
// 执行js
5、JsGetValueType(文档:https://github.com/microsoft/ChakraCore/wiki/JsGetValueType)
// 获取返回值类型(整型,字符串型,列表,字典等)
6、JsConvertValueToString(文档:https://github.com/microsoft/ChakraCore/wiki/JsConvertValueToString)
// 使用标准JavaScript语义将值转换为字符串。
7、JsStringToPointer(文档:https://github.com/microsoft/ChakraCore/wiki/JsStringToPointer)
// 检索字符串值的字符串指针。
8、JsDisposeRuntime(文档:https://github.com/microsoft/ChakraCore/wiki/JsDisposeRuntime)
// 处理runtime,类似于释放
三、附上实战代码:
1、加载dll,初始化数据
def __init__(self):
self.source = ''
self.dll = windll.LoadLibrary('ChakraCore.dll')
self.init_source = '''(function(){%s;return %s})()'''
self.count = 0
self.result = c_wchar_p('')
self._runtime = c_long(0)
self._context = c_long(0)
self._result = c_long(0)
self._type = c_long(0)
self._res_ptr = c_long(0)
self._length_ptr = c_long(0)
2、创建所需环境
def create_runtime(self):
return self.dll.JsCreateRuntime(0, None, pointer(self._runtime)) def create_context(self):
return self.dll.JsCreateContext(self._runtime, pointer(self._context)) def set_current_context(self):
return self.dll.JsSetCurrentContext(self._context)
3、组合js代码
def compile(self, source):
self.source = source
4、执行js并获取结果
def run(self, func, *args):
if not self._runtime:
self.create_runtime()
self.create_context()
self.set_current_context() target = '{name}{arg}'.format(name=func, arg=args)
js = self.init_source % (self.source, target)
self.count += 1
_run = self.dll.JsRunScript(c_wchar_p(js), self.count, c_wchar_p(''), pointer(self._result))
if _run:
self.dispose()
return 'JsRunScript Error!', False
return_type = self.dll.JsGetValueType(self._result, pointer(self._type))
if return_type:
self.dispose()
return 'Js Return Type Error!', False
if self._type.value == JsValueType_JsArray:
self.dispose()
return 'List wait', False
if self.dll.JsConvertValueToString(self._result, pointer(self.result)):
self.dispose()
return 'JsConvertValueToString Error', False
str_ptr = c_wchar_p('')
u_ptr = c_int(0)
res = self.dll.JsStringToPointer(self.result, pointer(str_ptr), pointer(u_ptr))
if res:
self.dispose()
return 'JsStringToPointer Error', False
else:
# print(str_ptr.value)
# self.dispose()
return str_ptr.value, True
5、释放runtime
def dispose(self):
# self.dll.JsSetCurrentContext(0)
self.result = c_wchar_p('')
self.count = 0
self.dll.JsDisposeRuntime(self._runtime) def __exit__(self, exc_type, exc_val, exc_tb):
self.result = c_wchar_p('')
self.count = 0
self.dll.JsDisposeRuntime(self._runtime)
四、所有源码如下:
from ctypes import * JsValueType_JsUndefined = 0 # 公开,该值是未定义的值。
JsValueType_JsNull = 1 # 公开,值为空值。
JsValueType_JsNumber = 2 # 公开,该值是JavaScript数值。
JsValueType_JsString = 3 # 公开,该值是JavaScript字符串值。
JsValueType_JsBoolean = 4 # 公开,该值是JavaScript布尔值。
JsValueType_JsObject = 5 # 公开,该值是JavaScript对象值。
JsValueType_JsFunction = 6 # 公开,该值是JavaScript函数对象值。
JsValueType_JsError = 7 # 公开,该值是JavaScript错误对象值。
JsValueType_JsArray = 8 # 公开,该值是JavaScript数组对象值。
JsValueType_JsSymbol = 9 # 公开,该值是JavaScript符号值。
JsValueType_JsArrayBuffer = 10 # 公开,该值是JavaScriptArrayBuffer对象值。
JsValueType_JsTypedArray = 11 # 公开,该值是JavaScript类型的数组对象值。
JsValueType_JsDataView = 12 # 公开,该值是JavaScriptDataView对象值。 class ChakraCore: def __init__(self):
self.source = ''
self.dll = windll.LoadLibrary('ChakraCore.dll')
self.init_source = '''(function(){%s;return %s})()'''
self.count = 0
self.result = c_wchar_p('')
self._runtime = c_long(0)
self._context = c_long(0)
self._result = c_long(0)
self._type = c_long(0)
self._res_ptr = c_long(0)
self._length_ptr = c_long(0) def compile(self, source):
self.source = source def create_runtime(self):
return self.dll.JsCreateRuntime(0, None, pointer(self._runtime)) def create_context(self):
return self.dll.JsCreateContext(self._runtime, pointer(self._context)) def set_current_context(self):
return self.dll.JsSetCurrentContext(self._context) def value(self, value):
if value == JsValueType_JsNumber:
self.result = c_float(0)
elif value == JsValueType_JsString:
self.result = c_wchar_p('')
if self.dll.JsConvertValueToString(self._result, pointer(self.result)):
return 'JsConvertValueToString Error'
str_ptr = c_wchar_p('')
u_ptr = c_int(0)
res = self.dll.JsStringToPointer(self.result, pointer(str_ptr), pointer(u_ptr))
if res:
return 'JsStringToPointer Error'
else:
return str_ptr.value
elif value == JsValueType_JsArray:
self.result = (c_wchar * 10)()
elif value == JsValueType_JsObject:
self.result = {}
else:
self.result = None def run(self, func, *args):
if not self._runtime:
self.create_runtime()
self.create_context()
self.set_current_context() target = '{name}{arg}'.format(name=func, arg=args)
js = self.init_source % (self.source, target)
self.count += 1
_run = self.dll.JsRunScript(c_wchar_p(js), self.count, c_wchar_p(''), pointer(self._result))
if _run:
self.dispose()
return 'JsRunScript Error!', False
return_type = self.dll.JsGetValueType(self._result, pointer(self._type))
if return_type:
self.dispose()
return 'Js Return Type Error!', False
if self._type.value == JsValueType_JsArray:
self.dispose()
return 'List wait', False
if self.dll.JsConvertValueToString(self._result, pointer(self.result)):
self.dispose()
return 'JsConvertValueToString Error', False
str_ptr = c_wchar_p('')
u_ptr = c_int(0)
res = self.dll.JsStringToPointer(self.result, pointer(str_ptr), pointer(u_ptr))
if res:
self.dispose()
return 'JsStringToPointer Error', False
else:
# print(str_ptr.value)
# self.dispose()
return str_ptr.value, True def dispose(self):
# self.dll.JsSetCurrentContext(0)
self.result = c_wchar_p('')
self.count = 0
self.dll.JsDisposeRuntime(self._runtime) def __exit__(self, exc_type, exc_val, exc_tb):
self.result = c_wchar_p('')
self.count = 0
self.dll.JsDisposeRuntime(self._runtime)
五、参考文献
使用案例GitHub源码:https://github.com/pyAppman/ChakraCore
本文主要讲下python调用ChakraCore.dll
参考文献有:https://xz.aliyun.com/t/2450 以及 https://bbs.125.la/forum.php?mod=viewthread&tid=14495171&highlight=ChakraCore
欢迎大家补充,没有太多的python文档借鉴,是自己一步一个脚印,爬坑爬出来的,好似盲人摸象。写的不好,还请轻喷。
python3调用微软js引擎ChakraCore的更多相关文章
- QML和JS引擎的关系以及调用c++函数的原理
首先推荐几篇博客 1.深入解析QML引擎, 第1部分:QML文件加载 https://www.cnblogs.com/wzxNote/p/10569535.html 2.深入解析QML引擎, 第2部分 ...
- JS引擎是如何工作的?从调用堆栈到Promise
摘要: 理解 JS 引擎运行原理. 作者:前端小智 原文:JS引擎:它们是如何工作的?从调用堆栈到Promise,需要知道的所有内容 Fundebug经授权转载,版权归原作者所有. 为了保证可读性,本 ...
- Js引擎解析执行 阅读笔记
Js引擎解析执行 阅读笔记 一篇阅读笔记 http://km.oa.com/group/2178/articles/show/145691?kmref=search&from_page=1&a ...
- 深入浏览器工作原理和JS引擎(V8引擎为例)
浏览器工作原理和JS引擎 1.浏览器工作原理 在浏览器中输入查找内容,浏览器是怎样将页面加载出来的?以及JavaScript代码在浏览器中是如何被执行的? 大概流程可观察以下图: 首先,用户在浏览器搜 ...
- 判断js引擎是javascriptCore或者v8
来由 纯粹的无聊,一直在搜索JavaScriptCore和SpiderMonkey的一些信息,却无意中学习了如何在ios的UIWebView中判断其js解析引擎的方法: if (window.de ...
- 【repost】浏览器内核、渲染引擎、js引擎
[1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具[2]常见引擎 渲染引擎: firef ...
- 浏览器内核、渲染引擎、js引擎
[1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具 [2]常见引擎 渲染引擎: fire ...
- 【转】浏览器内核、渲染引擎、js引擎
[1]定义 浏览器内核分成两部分渲染引擎和js引擎,由于js引擎越来越独立,内核就倾向于只指渲染引擎 渲染引擎是一种对HTML文档进行解析并将其显示在页面上的工具[2]常见引擎 渲染引擎: firef ...
- 在Android上使用Google V8 JS 引擎
在cantk-runtime中直接使用的webview,通过JAVA扩展接口把Canvas的2d Context的API定向到JNI,通过OpenGL来图形加速,渲染速度大大提高.后来测试发现在大部分 ...
随机推荐
- Centos7 设置自定义安装nginx的systemctl启动方式
一.systemctl方式启动设置过程 1.首先创建服务配置文件(名字和路径就是这个) vim /usr/lib/systemd/system/nginx.service 2.添加配置内容 [Unit ...
- C语言笔记 13_排序算法
排序算法 冒泡排序 冒泡排序(英语:Bubble Sort)是一种简单的排序算法.它重复地走访过要排序的数列,一次比较两个元素,如果他们的顺序(如从大到小.首字母从A到Z)错误就把他们交换过来. 过程 ...
- 算法设计与分析 - AC 代码 - 第 6 弹(重复第 3 弹)
PTA-算法设计与分析 - c++(g++) #include<bits/stdc++.h> using namespace std; long max3(long a,long b,lo ...
- sqlplus 登陆使用
select * from dept; input order by dname; 追加文本命令 del n 删除语句 celar buffer ; 清除缓冲区的命令 conn sys as ...
- VMwara虚拟机三种网络模式
虚拟机:虚拟机是能够让用户在一台物理机上模拟出多个操作系统的软件其本质是通过中间层实现计算机资源的管理和再分配让系统资源的利用率最大化VMware即是一款虚拟机软件注意:虚拟机和操作系统的区别,虚拟机 ...
- 微信内置浏览器video标签自动全屏的问题
微信打开h5video视频的时候都会自动全屏播放,有时候影响用户体验 要禁止自动全屏就要加这几个属性 'x5-playsinline':'true', 'webkit-playsinline':'tr ...
- redis api-zset
- 注册模块上线前安全测试checklist
许多应用系统都有注册模块,正常用户通过注册功能,获得应用系统使用权限:而非法用户通过注册模块,则是为了达到不可告人的目的,非法用户可以通过注册模块与服务端进行交互(一切用户输入都不可信),因此系统上线 ...
- 解决Eclipse Debug 断点调试的source not found问题
写完代码进行调试的时候,经常会用到断点调试,一步步检测问题,但有时候eclipse有时候无法进入断点,这样就失去了断点的意义,原因是debug无法找到该项目的源代码,解决方法如下 1,打开debug ...
- 配置<welcome-file>直接访问请求
方法一.配置welcome-file-list和servlet-mapping <!-- 将默认欢迎页配置为要访问的controller路径 --><welcome-file-lis ...