webassembly加载本地文件

参考官网文档 Using files

首先,对于webassembly而言,无法直接访问本地文件(即使是通过C/C++代码)。但是emscripten提供了File System Overview,可以在编译时将本地文件预加载到输出文件中,使得输出文件可以访问,具体步骤如下:

一、C代码

#include <stdio.h>

int main() {
  FILE *file = fopen("test.txt", "rb");
  if (!file) {
    printf("cannot open file\n");
    return 1;
  }
  while (!feof(file)) {
    char c = fgetc(file);
    if (c != EOF) {
      putchar(c);
    }
  }
  fclose (file);
  return 0;
}

命名为fileopt.c,并在同目录下创建test.txt文本文件,在其内保存一段文字。

二、编译

emcc -sEXIT_RUNTIME  -o fileopt.html fileopt.c --preload-file test.txt

其中EXIT_RUNTIME是为了确保文件流刷新,如果没有会有如下警告:

stdio streams had content in them that was not flushed. you should set EXIT_RUNTIME to 1 (see the FAQ), or make sure to emit a newline when you printf etc.

并且,输出内容不全。

编译完成后,本地会出现一个同名的*.data文件,这里面打包了所有的预置文件内容,当然我们也可以自己手动打包文件,参考Packaging Files

三、运行

双击运行。如果有同源策略问题(跨域问题)参考:html的同源策略问题

四、C++ example

代码

#include <iostream>
#include <fstream>
#include <filesystem>


using namespace std;
int main() {
	ifstream fin;
	fin.open("test.txt",ios::in);
	if(fin.is_open()){
		string s;
		while(getline(fin,s)){
			cout << s <<endl;
		}
		fin.close();
	}
	else{
		cout << "test.txt open failed" <<endl;
	}
	
	return 0;
}

命令

emcc -sEXIT_RUNTIME  -o fileopt.html fileopt.cpp --preload-file test.txt

五、扩展

如果每次都需要编译才能加载本地文件,那么易用性就会比较差。

但是首先对于单文件而言,直接替换*.data的内容即可生效;此外上面也提到可以通过package file的方式单独打包文件(待后续研究),所以还是比较方便的。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Qt WebAssembly 中,由于浏览器的安全限制,不能直接访问本地文件系统。但是可以通过使用 HTML5 的 File API,将本地文件读入内存中,然后在 WebAssembly 中进行处理。 以下是一个简单的示例代码,演示了如何从 WebAssembly读取本地文件: ```cpp #include <emscripten.h> #include <emscripten/bind.h> #include <string> #include <fstream> using namespace std; // 从本地文件读取数据 string read_file(const string& filename) { ifstream file(filename, ios::binary); if (!file) { return ""; } string content((istreambuf_iterator<char>(file)), istreambuf_iterator<char>()); return content; } // 在 JavaScript 中调用 read_file() 函数 EM_JS(std::string, js_read_file, (const char* filename), { return new Promise((resolve, reject) => { const xhr = new XMLHttpRequest(); xhr.open('GET', filename); xhr.responseType = 'blob'; xhr.onload = () => { if (xhr.status === 200) { const reader = new FileReader(); reader.onload = () => { resolve(reader.result); }; reader.readAsText(xhr.response); } else { reject(xhr.statusText); } }; xhr.onerror = () => { reject(xhr.statusText); }; xhr.send(); }); }); // 在 C++ 中调用 js_read_file() 函数 string wasm_read_file(const string& filename) { return js_read_file(filename.c_str()); } // 将函数暴露给 JavaScript EMSCRIPTEN_BINDINGS(my_module) { emscripten::function("read_file", &wasm_read_file); } ``` 在这个示例中,我们定义了一个 C++ 函数 `read_file()` 来读取本地文件。然后,我们使用 `EM_JS()` 宏来定义一个名为 `js_read_file()` 的 JavaScript 函数,该函数通过 XMLHttpRequest 对象来异步加载指定的文件,并使用 FileReader 对象将文件内容读取为字符串并返回。最后,我们定义了另一个 C++ 函数 `wasm_read_file()`,该函数调用 `js_read_file()` 函数并返回文件内容。最后,我们使用 `EMSCRIPTEN_BINDINGS()` 宏将 `wasm_read_file()` 函数暴露给 JavaScript。 ### 回答2: 在Qt中使用WebAssembly读取本地文件,可以通过以下步骤实现: 第一步,将本地文件加载到内存中。可以使用Qt的QFile类读取文件内容,并将文件内容存储到一个QByteArray对象中。 第二步,将读取文件内容转换为Base64编码的字符串。可以使用Qt的QByteArray的toBase64方法将文件内容转换为Base64编码的字符串。 第三步,将Base64编码的字符串传递给WebAssembly。可以使用Qt的QWebChannel类从Qt应用程序向WebAssembly应用程序传递数据。在Qt应用程序中,可以创建一个QWebChannel对象,并通过调用QWebChannel的registerObject方法将一个QObject子类对象注册到QWebChannel上。在WebAssembly应用程序中,可以使用JavaScript的XMLHttpRequest对象发送请求,并将Base64编码的字符串作为请求体发送给Qt应用程序。 第四步,在WebAssembly中处理接收到的文件内容。在Qt应用程序中,可以在已注册的QObject子类对象中实现一个槽函数,用于接收来自WebAssembly文件内容。在WebAssembly应用程序中,可以使用JavaScript的XMLHttpRequest对象的onload事件处理程序来处理接收到的响应。在事件处理程序中,可以将接收到的Base64编码的字符串解码,并对文件内容进行进一步处理。 通过上述步骤,可以在Qt中使用WebAssembly读取本地文件。注意,由于WebAssembly的沙箱限制,通常无法直接访问本地文件系统。因此,需要通过将文件内容加载到内存中,并通过Base64编码传递给WebAssembly来实现本地文件读取。 ### 回答3: 在Qt WebAssembly中,读取本地文件是一个相对复杂的过程,因为WebAssembly的运行环境是基于浏览器的,并且对于安全原因,浏览器限制了WebAssembly的访问本地文件系统的能力。但是,我们可以通过一些技巧和工具来实现读取本地文件的需求。 一种方法是使用WebAssembly的File System API,该API允许WebAssembly模块创建、读取和写入文件。通过这个API,我们可以模拟本地文件系统的行为。但是需要注意的是,这种方法只适用于在WebAssembly模块内部模拟文件系统,而不能直接访问真实的本地文件。 另一种方法是使用emscripten工具链,该工具链可以将C/C++代码编译成可以在WebAssembly中运行的JavaScript代码。通过emscripten提供的函数和工具,我们可以在JavaScript中实现本地文件读取操作,然后将读取到的数据传递给WebAssembly模块进行处理。 具体来说,我们可以使用emscripten提供的函数`FS.readFile`来读取本地文件。首先,我们需要将文件加载到JavaScript中,然后使用`FS.readFile`来读取文件的内容。读取到的内容可以以字符串或二进制形式传递给WebAssembly模块进行后续处理。 需要注意的是,使用emscripten进行文件读取需要在编译时配置相关选项,并且在页面中加载生成的JavaScript文件WebAssembly模块。 综上所述,在Qt WebAssembly读取本地文件是通过一些技巧和工具来实现的,如模拟文件系统或使用emscripten工具链。这些方法可以满足我们对于读取本地文件的需求,但也需要注意安全和浏览器环境的限制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值