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来图形加速,渲染速度大大提高.后来测试发现在大部分 ...
随机推荐
- Interlocked.Increment()函数详解 (转载)
原文地址 class Program { static object lockObj = new object(); ; ; //假设要处理的数据源 , ).ToList(); static void ...
- 「CSP-S」2019年第一届Day1游记+题解
「CSP-S」2019年第一届Day1游记+题解 Day 1 7:30 A.M. 8:10 A.M. 8:30 A.M. T1 格雷码 题目 考场经历+思考(正解) 8:50 A.M. T2 括号树 ...
- 「CSP-S模拟赛」2019第四场
「CSP-S模拟赛」2019第四场 T1 「JOI 2014 Final」JOI 徽章 题目 考场思考(正解) T2 「JOI 2015 Final」分蛋糕 2 题目 考场思考(正解) T3 「CQO ...
- python基础面试题1
Python面试重点(基础篇) 注意:只有必答题部分计算分值,补充题不计算分值. 第一部分 必答题(每题2分) 简述列举了解的编程语言及语言间的区别? c语言是编译型语言,运行速度快,但翻译时间长py ...
- SQL中limit的用法
limit子句用于限制查询结果返回的数量 格式: select * from tableName limit i,n # tableName:表名 # i:为查询结果的索引值(默认从0开始),当i=0 ...
- jQuery加减
var num1 = 123; var num2=123; var sum = num1+num2; 结果是246; <input type="text" id=" ...
- eclipse不能启动,An internal error occurred during: "reload maven project".
An internal error occurred during: "reload maven project". 这个错误是因为项目已经关闭,导致 导致此问题的原因是Sprin ...
- Linux CentOS7 VMware 文件和目录权限chmod、更改所有者和所属组chown、umask、隐藏权限lsattr/chattr
一.文件和目录权限chmod u User,即文件或目录的拥有者:g Group,即文件或目录的所属群组:o Other,除了文件或目录拥有者或所属群组之外,其他用户皆属于这个范围:a All,即全部 ...
- 防止SQL注入的登录页面
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN""http://www.w3.org/T ...
- js默认字符处理
utf-16 每个字符是2个字节 超过2字节,就是4个字节表示