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来图形加速,渲染速度大大提高.后来测试发现在大部分 ...
随机推荐
- python爬虫处理在线预览的pdf文档
引言 最近在爬一个网站,然后爬到详情页的时候发现,目标内容是用pdf在线预览的 比如如下网站: https://camelot-py.readthedocs.io/en/master/_static/ ...
- PHP常用的一些优化技巧
PHP常用的一些优化技巧 点击联系老杨 ecshop模板 php 优化技巧 老杨ecshop ecshop二次开发 2013-03-29 0 做为最流行的WEB语言, PHP他的突出优势就是其速度与效 ...
- iframe切换
iframe(locator有三种情况,可以是:定位表达式(driver.find_element_by_xpath()),frame的名称,下标index) driver.switch_to.fra ...
- Wepy框架和mpVue框架的比较及使用mpVue框架需要注意的点
Wepy框架 它是一款类Vue框架,在代码风格上借鉴了Vue,本身和Vue没有任何关系. mpVue框架 它是从整个Vue的核心代码上经过二次开发而形成的一个框架,相当于是给Vue本身赋能,增加了开发 ...
- 如何发布composer包
1. 首先要有github仓库(其中必须要有 composer.json 配置文件) 2.关联 github 项目 提交成功 3.设置钩子以便同步更新 https://packagist.org/ab ...
- 报警视图 报警窗口 报警指示器 的组态 PLC变量 事故信息 MW16 报警确认变量 MW18 转速变量 MW20 温度变量 MW22 用 M17.0 来模拟事故信息的最低位。用PLCSIM 给定温度为800 度 报警视图与报警窗口显示故障
组态报警并用PLCSIM进行仿真 步骤1 : 组态离散变量报警 在PLC 的默认变量表中 创建变量"事故信息" 数据类型是word 绝对地址是MW16 同时建立 报警确认变量 MW ...
- 提高 Java 代码性能的各种技巧
Java 6,7,8 中的 String.intern – 字符串池 这篇文章将要讨论 Java 6 中是如何实现 String.intern 方法的,以及这个方法在 Java 7 以及 Java 8 ...
- save the transient instance before flushing错误解决办法
错误原因: new了一个新对象,在未保存之前将它保存进了一个新new的对象(也即不是持久态). 解决办法: 在保存或更新之前把这个对象查出来(这样就是一个持久态) <set name=" ...
- Android 四种加载方式详解(standard singleTop singleTask singleInstance) .
Android之四种加载方式 (http://marshal.easymorse.com/archives/2950 图片) 在多Activity开发中,有可能是自己应用之间的Activity跳转,或 ...
- Python 动态从文件中导入类或函数的方法
假设模块文件名是data_used_to_test.py,放在tests文件夹下 文件夹结构如下: project |-tests |-data_used_to_test.py 文件内包含一个test ...