可以通过让webview嵌入javascript代码从设备存储读取文件内容来解决这个问题,以避免内联这个大的base64文本。
如上所述
here
,建议的解决方法是使用blob url。
基本上你必须:
-
一
进口
RNFetchBlob
和
simpleCrypto
在网络视图中。(见
here
)
-
二
:获取文件并解密,
-
三
:创建blob url并将其设置为
<video>
src属性。
您的代码将如下所示:
componentDidMount() {
this.setState({htmlCode: `
<html>
<body>
<video id="myvideo" style="width: 50%; height: 50%; margin-top: 10%; margin-left: 22%;" controls></video>
<script src="${RNFetchBlob.fs.dirs.MainBundleDir}/bundle.js"></script>
<script src="${path/to/simpleCrypto.js}"></script>
<script type="text/javascript">
function b64toBlob(b64Data, contentType, sliceSize) {
//... returns a new Blob using the b64Data.
}
//for simplicity, onDecodeEnd abstracts your decryption code
RNFetchBlob.fs.readStream('encryptfile1.dat').onDecodeEnd((decryptText) => {
var blob = b64toBlob(base64Video, "video/mp4");
var url = URL.createObjectURL(blob);
document.getElementById('myvideo').src = url;
})
</script>
</body>
</html>
`})
render() {
return (
<WebView
style={{ flex: 1 }}
source={{ html: this.state.htmlCode, baseUrl: RNFetchBlob.fs.dirs.DCIMDir }}>
</WebView>
);
}
免责声明
-
1:我能够使用WebVIEW来复制您的限制问题,WebVIEW嵌入了一个大的Base64内联文字(2.5MB)。它适用于850kbbase64视频。
-
2:blob url方法通过获取包含较大base64视频的远程json文件,确实解决了web视图的这一限制。
-
3:我没有测试将rnfetchblob导入webview方法。再次,如前所述
here
似乎很管用。
附加代码
function b64toBlob(b64Data, contentType, sliceSize) {
contentType = contentType || '';
sliceSize = sliceSize || 512;
var byteCharacters = atob(b64Data);
var byteArrays = [];
for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
var slice = byteCharacters.slice(offset, offset + sliceSize);
var byteNumbers = new Array(slice.length);
for (var i = 0; i < slice.length; i++) {
byteNumbers[i] = slice.charCodeAt(i);
}
var byteArray = new Uint8Array(byteNumbers);
byteArrays.push(byteArray);
}
var blob = new Blob(byteArrays, {type: contentType});
return blob;
}
聚苯乙烯
我本人不赞成这种Base64方法。我更希望有一些本机代码,由react native触发,用于编写和读取加密视频。读取将生成一个temp.mp4,从
react-native-video
模块。在幕后,加密是在字节级完成的。所以我们不需要来回解析到base64。我们毕竟是在处理二进制文件。