Dlaczego wywołanie api requestQuota systemu plików nie powiedzie się?
Piszę aplikację HTML5 do uruchomienia w Chrome, ale będzie ona w lokalnym systemie plików (więc uruchomią ją, klikając dwukrotnie plik html). Zgłasza błąd, gdy próbuję uzyskać dostęp do systemu plików i myślę, że to dlatego, że jest to plik lokalny. Czy istnieje sposób, aby Chrome na to zezwolił?
(UWAGA: pojawia się okienko z prośbą o zezwolenie aplikacji na trwałe przechowywanie i klikam „OK”. Nadal zgłaszany jest ten błąd)
Poniższy kod zgłasza błąd:
DOMException {message: "NotSupportedError: DOM Exception 9", name: "NotSupportedError", code: 9, INDEX_SIZE_ERR: 1, DOMSTRING_SIZE_ERR: 2…}
filetest.html
<!DOCTYPE html>
<html>
<head></head>
<body>
<script>
//File System handler
window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem;
function onInitFs(fs) {
console.log('Opened file system: ' + fs.name);
}
function errorHandler(e) {
var msg = '';
switch (e.code) {
case FileError.QUOTA_EXCEEDED_ERR:
msg = 'QUOTA_EXCEEDED_ERR';
break;
case FileError.NOT_FOUND_ERR:
msg = 'NOT_FOUND_ERR';
break;
case FileError.SECURITY_ERR:
msg = 'SECURITY_ERR';
break;
case FileError.INVALID_MODIFICATION_ERR:
msg = 'INVALID_MODIFICATION_ERR';
break;
case FileError.INVALID_STATE_ERR:
msg = 'INVALID_STATE_ERR';
break;
default:
msg = 'Unknown Error';
break;
};
console.log('Error: ' + msg);
}
/** THIS CAUSES IT TO THROW AN ERROR */
window.webkitStorageInfo.requestQuota(window.PERSISTENT, 5*1024*1024, function(grantedBytes) {
window.requestFileSystem(window.PERSISTENT, grantedBytes, onInitFs, errorHandler);
}, function(e) {
console.log('Error', e);
});
</script>
</body>
</html>
Jeśli zamiast tego zmienię go, aby poprosić o tymczasowe przechowywanie, nadal generuje błąd, ale teraz jest to błądSECURITY_ERR
:
window.requestFileSystem(window.TEMPORARY, 5*1024*1024, onInitFs, errorHandler);