Merge remote-tracking branch 'origin/master'

This commit is contained in:
kunfei 2023-03-29 09:23:17 +08:00
commit 8a7a05a37a
2 changed files with 42 additions and 1 deletions

View File

@ -34,6 +34,7 @@ class JsTest {
val jsMap = "$=result;id=$.id;id"
val result = SCRIPT_ENGINE.eval(jsMap, bindings)?.toString()
Assert.assertEquals("3242532321", result)
@Language("js")
val jsMap1 = """result.get("id")"""
val result1 = SCRIPT_ENGINE.eval(jsMap1, bindings)?.toString()
Assert.assertEquals("3242532321", result1)
@ -95,4 +96,42 @@ class JsTest {
Assert.assertEquals(result, ",。!?……;:")
}
@Test
fun testPackages() {
@Language("js")
val js = """
var accessKeyId = '1111';
var accessKeySecret = '2222';
var timestamp = '3333';
var aly = new JavaImporter(Packages.javax.crypto.Mac, Packages.javax.crypto.spec.SecretKeySpec, Packages.javax.xml.bind.DatatypeConverter, Packages.java.net.URLEncoder, Packages.java.lang.String, Packages.android.util.Base64);
with (aly) {
function percentEncode(value) {
return URLEncoder.encode(value, "UTF-8").replace("+", "%20")
.replace("*", "%2A").replace("%7E", "~")
}
function sign(stringToSign, accessKeySecret) {
var mac = Mac.getInstance('HmacSHA1');
mac.init(new SecretKeySpec(String(accessKeySecret + '&').getBytes("UTF-8"), "HmacSHA1"));
var signData = mac.doFinal(String(stringToSign).getBytes("UTF-8"));
var signBase64 = Base64.encodeToString(signData, Base64.NO_WRAP);
var signUrlEncode = percentEncode(signBase64);
return signUrlEncode;
}
}
var query = 'AccessKeyId=' + accessKeyId + '&Action=CreateToken&Format=JSON&RegionId=cn-shanghai&SignatureMethod=HMAC-SHA1&SignatureNonce=' + "xxccrr" + '&SignatureVersion=1.0&Timestamp=' + percentEncode(timestamp) + '&Version=2019-02-28';
var signStr = sign('GET&' + percentEncode('/') + '&' + percentEncode(query), accessKeySecret);
var queryStringWithSign = "Signature=" + signStr + "&" + query;
queryStringWithSign
""".trimIndent()
SCRIPT_ENGINE.eval(js)
@Language("js")
val js1 = """
var returnData = new Packages.io.legado.app.api.ReturnData()
returnData.getErrorMsg()
""".trimIndent()
val result1 = SCRIPT_ENGINE.eval(js1)
Assert.assertEquals(result1, "未知错误,请联系开发者!")
}
}

View File

@ -11,7 +11,7 @@
* 正文出现缺字漏字、内容缺失、排版错乱等情况,有可能是净化规则或简繁转换出现问题。
* 漫画源看书显示乱码,**阅读与其他软件的源并不通用**,请导入阅读的支持的漫画源!
**2023/03/24**
**2023/03/28**
* 更新cronet: 111.0.5563.115
* 更新rhino: 1.7.14-2
@ -23,6 +23,8 @@
{bookId: 1}
https://www.example.com/book/{{result.bookId}}
```
* 书架整理搜索支持分类和简介
* 其中一些更新由 Xwite, Horis提供
**2023/03/21**