首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Blazor调用SnarkJS

Blazor调用SnarkJS
EN

Stack Overflow用户
提问于 2022-09-02 17:14:19
回答 1查看 62关注 0票数 0

对于SnarkJS (https://github.com/iden3/snarkjs),有一个HTML示例显示了如何使用它们的ES6 javascript库:

代码语言:javascript
复制
<!doctype html>
<html>
<body>

  <script src="snarkjs.min.js">   </script>
  <script>

async function calculateProof() {

    const { proof, publicSignals } =
      await snarkjs.groth16.fullProve( { a: 3, b: 11}, "circuit.wasm", "circuit_final.zkey");
      
  </script>

</body>
</html>

这个对snarkjs.groth16.FulProve的调用在浏览器中工作得很好。

在Blazor中,我将snarkjs.min.js加载到一个IJSObjectReference (myJSmodule)中,但我不知道如何模拟snarkjs.groth16。类似于:

代码语言:javascript
复制
await myJSmodule.InvokeVoidAsync("snarkjs.groth16.fullProve", args...)

但这就产生了

找不到“snarkjs.groth16”.“snarkjs”未定义

编辑:最后,我遇到了两个问题:

  1. Chrome缓存我的嵌入式javascript (而不是动态加载的模块),因此运行该应用程序将导致它使用过时的缓存javascript。解决方案是长时间点击Chrome刷新按钮,并选择“空缓存和硬重放”。不过,我不确定这对部署的面向消费者的网站是否是好兆头。

  1. Dimitris在下面的回答中谈到了第二个问题。
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-09-02 18:09:41

您可以创建一个helper js模块,该模块导出calculateProof函数:

snarkJsInteropHelper.js

代码语言:javascript
复制
export async function calculateProof() {
    const { proof, publicSignals } =
        await snarkjs.groth16.fullProve({ a: 3, b: 11 }, "circuit.wasm", "circuit_final.zkey");
}

然后在blazor组件中:

代码语言:javascript
复制
protected override async Task OnAfterRenderAsync(bool firstRender)
{
    if (firstRender)
    {
        var module = await JS.InvokeAsync<IJSObjectReference>(
          "import", "./snarkJsInteropHelper.js");

        await module.InvokeVoidAsync("calculateProof");
    }
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73586009

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档