codecamp

Deno 完整性检查与锁定文件

介绍

假设您的模块依赖于远程模块 https://some.url/a.ts。当第一次编译您的模块时,a.ts 被下载、编译、缓存。它将保持这样,直到您在一个新的机器上运行您的模块(生产环境?)或是重新加载缓存(例如通过 deno cache --reload)。但当 https://some.url/a.ts 的内容变化时会发生什么?这将导致您的生产模块使用了和本地模块不同的依赖。Deno 的解决方法是使用完整性检查与锁定文件。

缓存与锁定文件

Deno 可以使用一个较小的 JSON 文件存储和检查模块的子资源完整性。 使用 --lock=lock.json 启用和指定锁文件检查。 要更新或创建锁,可以使用 --lock=lock.json --lock-write。--lock=lock.json 告诉 Deno 要使用哪个锁文件,--lock-write 用来向锁文件输出依赖的哈希值。 (--lock-write 必须和 --lock 一起使用) 一个锁文件可能看起来像这样,针对依赖项存储文件的哈希值: { "https://deno.land/std@v0.50.0/textproto/mod.ts": "3118d7a42c03c242c5a49c2ad91c8396110e14acca1324e7aaefd31a999b71a4", "https://deno.land/std@v0.50.0/io/util.ts": "ae133d310a0fdcf298cea7bc09a599c49acb616d34e148e263bcb02976f80dee", "https://deno.land/std@v0.50.0/async/delay.ts": "35957d585a6e3dd87706858fb1d6b551cb278271b03f52c5a2cb70e65e00c26a", ... }

运行时验证

像上面的缓存一样,您也可以在使用 deno run 子命令时配合--lock=lock.json 选项,从而在运行期间验证所有被锁定的模块的完整性。请记住,这只会针对先前添加到 lock.json 文件中的依赖项进行验证。新的依赖项将被缓存,但不会被检验。 您也可以通过使用 --cached-only 选项来要求远程依赖都已经被缓存。 deno run --lock=lock.json --cached-only mod.ts 如果依赖树中有尚未缓存的 mod.ts 依赖项,此操作将失败。

Deno 重新加载模块
Deno 代理
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Deno 标准库

Deno 测试

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }