[skip ci] doc: update jsHelp.md

This commit is contained in:
Xwite 2024-05-03 14:49:02 +08:00
parent 5126ec0cd2
commit d38331b8bd

View File

@ -1,17 +1,35 @@
# js变量和函数
> 阅读使用[Rhino](https://github.com/mozilla/rhino)作为JavaScript引擎以便于[调用Java类和方法](https://m.jb51.net/article/92138.htm),查看[ECMAScript兼容性表格](https://mozilla.github.io/rhino/compat/engines.html)
书源规则中使用js可访问以下变量
> java 变量-当前类
> baseUrl 变量-当前url,String
> result 变量-上一步的结果
> book 变量-[书籍类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/Book.kt)
> chapter 变量-[当前目录类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/BookChapter.kt)
> source 变量-[基础书源类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/BaseSource.kt)
> cookie 变量-[cookie操作类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/help/http/CookieStore.kt)
> cache 变量-[缓存操作类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/help/CacheManager.kt)
> title 变量-当前标题,String
> src 内容,源码
> nextChapterUrl 变量 下一章节url
> [Rhino运行时](https://github.com/mozilla/rhino/blob/master/src/org/mozilla/javascript/ScriptRuntime.java#L299)懒加载导入的Java类和方法
|构造函数|函数|对象|调用类|简要说明|
|------|-----|------|----|------|
|JavaImporter|ImportClass ImportPackage| |[ImporterTopLevel](https://github.com/mozilla/rhino/blob/master/src/org/mozilla/javascript/ImporterTopLevel.java#L147-L190)|导入Java类到JavaScript|
||getClass|Packages java javax ...|[NativeJavaTopPackage](https://github.com/mozilla/rhino/blob/master/src/org/mozilla/javascript/NativeJavaTopPackage.java#L66-L104)|默认导入JavaScript中的Java类|
|JavaAdapter|||[JavaAdapter](https://github.com/mozilla/rhino/blob/master/src/org/mozilla/javascript/JavaAdapter.java)|继承Java类|
> 注意`java`变量指向已经被阅读修改,如果想要调用`java.*`下的包,请使用`Packages.java.*`
> 在书源规则中使用`@js` `<js>` `{{}}`可使用JavaScript调用阅读部分内置的类和方法
> 注意为了安全阅读会屏蔽部分java类调用见[RhinoClassShutter](https://github.com/gedoor/legado/blob/master/modules/rhino/src/main/java/com/script/rhino/RhinoClassShutter.kt)
> 不同的书源规则中支持的调用的Java类和方法可能有所不同
|变量名|调用类|
|------|-----|
|java|当前类|
|baseUrl|当前url,String |
|result|上一步的结果|
|book|[书籍类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/Book.kt)|
|chapter|[章节类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/BookChapter.kt)|
|source|[基础书源类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/data/entities/BaseSource.kt)|
|cookie|[cookie操作类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/help/http/CookieStore.kt)|
|cache|[缓存操作类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/help/CacheManager.kt)|
|title|章节当前标题 String|
|src| 请求返回的源码|
|nextChapterUrl|下一章节url|
## 当前类对象的可使用的部分方法
@ -22,20 +40,19 @@
* 调用阅读搜索
```
java.searchBook(
bookName)
```js
java.searchBook(bookName: string)
```
* 添加书架
```
```js
java.addBook(bookUrl)
```
### [AnalyzeUrl](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/model/analyzeRule/AnalyzeUrl.kt) 部分函数
> js中通过java.调用,只在`登录检查JS`规则中有效
```
```js
initUrl() //重新解析url,可以用于登录检测js登录后重新解析url重新访问
getHeaderMap().putAll(source.getHeaderMap(true)) //重新设置登录头
getStrResponse( jsStr: String? = null, sourceRegex: String? = null) //返回访问结果,文本类型,书源内部重新登录后可调用此方法重新返回结果
@ -46,13 +63,13 @@ getResponse(): Response //返回访问结果,网络朗读引擎采用的是这
* 获取文本/文本列表
> `mContent` 待解析源代码,默认为当前页面
> `isUrl` 链接标识,默认为`false`
```
```js
java.getString(ruleStr: String?, mContent: Any? = null, isUrl: Boolean = false)
java.getStringList(ruleStr: String?, mContent: Any? = null, isUrl: Boolean = false)
```
* 设置解析内容
```
```js
java.setContent(content: Any?, baseUrl: String? = null):
```
@ -60,7 +77,7 @@ java.setContent(content: Any?, baseUrl: String? = null):
> 如果要改变解析源代码,请先使用`java.setContent`
```
```js
java.getElement(ruleStr: String)
java.getElements(ruleStr: String)
```
@ -69,13 +86,13 @@ java.getElements(ruleStr: String)
> 可以在刷新目录之前使用,有些书源书籍地址和目录url会变
```
```js
java.reGetBook()
java.refreshTocUrl()
```
* 变量存取
```
```js
java.get(key)
java.put(key, value)
```
@ -83,14 +100,16 @@ java.put(key, value)
### [js扩展类](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/help/JsExtensions.kt) 部分函数
* 链接解析[JsURL](https://github.com/gedoor/legado/blob/master/app/src/main/java/io/legado/app/utils/JsURL.kt)
```
```js
java.toURL(url): JsURL
java.toURL(url, baseUrl): JsURL
```
* 网络请求
* 获取SystemWebView User-Agent
```js
java.getWebViewUA(): String
```
* 网络请求
```js
java.ajax(urlStr): String
java.ajaxAll(urlList: Array<String>): Array<StrResponse?>
//返回Response 方法body() code() message() header() raw() toString()
@ -124,28 +143,28 @@ java.startBrowser(url: String, title: String)
java.startBrowserAwait(url: String, title: String): StrResponse
```
* 调试
```
```js
java.log(msg)
java.logType(var)
```
* 获取用户输入的验证码
```
```js
java.getVerificationCode(imageUrl)
```
* 弹窗提示
```
```js
java.longToast(msg: Any?)
java.toast(msg: Any?)
```
* 从网络(由java.cacheFile实现)、本地读取JavaScript文件导入上下文请手动`eval(String(...))`
```
```js
java.importScript(url)
//相对路径支持android/data/{package}/cache
java.importScript(relativePath)
java.importScript(absolutePath)
```
* 缓存网络文件
```
```js
获取
java.cacheFile(url)
java.cacheFile(url,saveTime)
@ -155,7 +174,7 @@ eval(String(java.cacheFile(url)))
cache.delete(java.md5Encode16(url))
```
* 获取网络压缩文件里面指定路径的数据 *可替换Zip Rar 7Z
```
```js
java.get*StringContent(url: String, path: String): String
java.get*StringContent(url: String, path: String, charsetName: String): String
@ -165,14 +184,14 @@ java.get*ByteArrayContent(url: String, path: String): ByteArray?
```
* base64
> flags参数可省略默认Base64.NO_WRAP查看[flags参数说明](https://blog.csdn.net/zcmain/article/details/97051870)
```
```js
java.base64Decode(str: String)
java.base64Decode(str: String, charset: String)
java.base64DecodeToByteArray(str: String, flags: Int)
java.base64Encode(str: String, flags: Int)
```
* ByteArray
```
```js
Str转Bytes
java.strToBytes(str: String)
java.strToBytes(str: String, charset: String)
@ -181,7 +200,7 @@ java.bytesToStr(bytes: ByteArray)
java.bytesToStr(bytes: ByteArray, charset: String)
```
* Hex
```
```js
HexString 解码为字节数组
java.hexDecodeToByteArray(hex: String)
hexString 解码为utf8String
@ -190,20 +209,24 @@ utf8 编码为hexString
java.hexEncodeToString(utf8: String)
```
* 标识id
```
```js
java.randomUUID()
java.androidId()
```
* 繁简转换
```
```js
将文本转换为简体
java.t2s(text: String): String
将文本转换为繁体
java.s2t(text: String): String
```
* 时间格式化
```js
java.timeFormatUTC(time: Long, format: String, sh: Int): String?
```
* 文件
> 所有对于文件的读写删操作都是相对路径,只能操作阅读缓存/android/data/{package}/cache/内的文件
```
```js
//文件下载 url用于生成文件名返回文件路径
downloadFile(url: String): String
//文件解压,zipPath为压缩文件路径返回解压路径
@ -224,19 +247,15 @@ deleteFile(path: String)
> 提供在JavaScript环境中快捷调用crypto算法的函数由[hutool-crypto](https://www.hutool.cn/docs/#/crypto/概述)实现
> 由于兼容性问题hutool-crypto当前版本为5.8.22
> 其他没有添加的算法可在JavaScript中使用`JavaImporter`[调用](https://m.jb51.net/article/92138.htm)Java例子可参考`朗读引擎-阿里云语音`
> 注意阅读app会屏蔽部分java类调用见[RhinoClassShutter](https://github.com/gedoor/legado/blob/master/modules/rhino/src/main/java/com/script/rhino/RhinoClassShutter.kt)
> 注意如果输入的参数不是Utf8String 可先调用`java.hexDecodeToByteArray java.base64DecodeToByteArray`转成ByteArray
* 对称加密
> 输入参数key iv 支持ByteArray|**Utf8String**
```
```js
// 创建Cipher
java.createSymmetricCrypto(transformation, key, iv)
```
>解密加密参数 data支持ByteArray|Base64String|HexString|InputStream
```
```js
//解密为ByteArray String
cipher.decrypt(data)
cipher.decryptStr(data)
@ -247,7 +266,7 @@ cipher.encryptHex(data)
```
* 非对称加密
> 输入参数 key支持ByteArray|**Utf8String**
```
```js
//创建cipher
java.createAsymmetricCrypto(transformation)
//设置密钥
@ -256,7 +275,7 @@ java.createAsymmetricCrypto(transformation)
```
> 解密加密参数 data支持ByteArray|Base64String|HexString|InputStream
```
```js
//解密为ByteArray String
cipher.decrypt(data, usePublicKey: Boolean? = true
)
@ -272,7 +291,7 @@ cipher.encryptHex(data, usePublicKey: Boolean? = true
```
* 签名
> 输入参数 key 支持ByteArray|**Utf8String**
```
```js
//创建Sign
java.createSign(algorithm)
//设置密钥
@ -280,24 +299,24 @@ java.createSign(algorithm)
.setPrivateKey(key)
```
> 签名参数 data支持ByteArray|inputStream|String
```
```js
//签名输出 ByteArray HexString
sign.sign(data)
sign.signHex(data)
```
* 摘要
```
```js
java.digestHex(data: String, algorithm: String,): String?
java.digestBase64Str(data: String, algorithm: String,): String?
```
* md5
```
```js
java.md5Encode(str)
java.md5Encode16(str)
```
* HMac
```
```js
java.HMacHex(data: String, algorithm: String, key: String): String
java.HMacBase64(data: String, algorithm: String, key: String): String
@ -306,7 +325,7 @@ java.HMacBase64(data: String, algorithm: String, key: String): String
## book对象的可用属性
### 属性
> 使用方法: 在js中或{{}}中使用book.属性的方式即可获取.如在正文内容后加上 ##{{book.name+"正文卷"+title}} 可以净化 书名+正文卷+章节名称(如 我是大明星正文卷第二章我爸是豪门总裁) 这一类的字符.
```
```js
bookUrl // 详情页Url(本地书源存储完整文件路径)
tocUrl // 目录页Url (toc=table of Contents)
origin // 书源URL(默认BookType.local)
@ -339,7 +358,7 @@ variable // 自定义书籍变量信息(用于书源规则检索书籍信息)
## chapter对象的部分可用属性
> 使用方法: 在js中或{{}}中使用chapter.属性的方式即可获取.如在正文内容后加上 ##{{chapter.title+chapter.index}} 可以净化 章节标题+序号(如 第二章 天仙下凡2) 这一类的字符.
```
```js
url // 章节地址
title // 章节标题
baseUrl //用来拼接相对url
@ -354,17 +373,17 @@ variable // 自定义书籍变量信息(用于书源规则检索书籍信息)
## source对象的部分可用函数
* 获取书源url
```
```js
source.getKey()
```
* 书源变量存取
```
```js
source.setVariable(variable: String?)
source.getVariable()
```
* 登录头操作
```
```js
source.getLoginHeader()
source.getLoginHeaderMap().get(key: String)
source.putLoginHeader(header: String)
@ -372,13 +391,13 @@ source.removeLoginHeader()
```
* 用户登录信息操作
> 使用`登录UI`规则并成功登录阅读自动加密保存登录UI规则中除type为button的信息
```
```js
source.getLoginInfo()
source.getLoginInfoMap().get(key: String)
source.removeLoginInfo()
```
## cookie对象的部分可用函数
```
```js
获取全部cookie
cookie.getCookie(url)
获取cookie某一键值
@ -390,7 +409,7 @@ cookie.removeCookie(url)
## cache对象的部分可用函数
> saveTime单位:秒,可省略
> 保存至数据库和缓存文件(50M),保存的内容较大时请使用`getFile putFile`
```
```js
保存
cache.put(key: String, value: Any , saveTime: Int)
读取数据库
@ -406,4 +425,4 @@ cache.deleteMemory(key: String)
cache.getFromMemory(key: String): Any?
cache.putMemory(key: String, value: Any)
```
```