我已经在jupyter笔记本上运行了大约26个小时的脚本;我没有真正使用我的电脑做任何其他事情,但它需要运行这个程序,需要大约30个小时才能完成。大约21小时后,它停止保存,我的终端出现了这样的情况:

403 PUT /api/contents/[file.ipynb] (::1): '_xsrf' argument missing from POST

(文件的地方。Ipynb]是我的jupyter笔记本的位置。它还说:

'_xsrf' argument missing from post

在笔记本的右上角。程序仍在运行,我不想重新启动jupyter notebook,不得不再次运行程序,因为我有一个截止日期,还有什么我可以做的吗?

我使用谷歌chrome,但我没有LastPass扩展或任何'%'字符在我的代码,作为另一个帖子建议。

谢谢你的帮助!


当前回答

我只需要刷新树选项卡就可以了。

其他回答

你可以通过启动JupyterLab来禁用XSRF检查:

jupyter lab --ServerApp.disable_check_xsrf=True

这可能意味着您的服务器没有经过令牌验证。例如,您可能已经启动了JupyterLab:

jupyter lab --NotebookApp.token='' --NotebookApp.password=''

这也可能意味着您在本地机器上运行JupyterLab,而您的服务器无法远程访问,所以这没有问题。

但是通常要注意,如果您的服务器没有身份验证,那么它很容易受到XSRF的攻击。

我相信有足够的解决方案来解决这个问题。 但是为了防止有人想知道为什么会出现这个错误:

当您试图向Jupyter笔记本服务器发出POST请求时,通常会遇到“XSRF参数missing from POST”错误,并且服务器无法验证请求是否合法。

当请求缺少所需的XSRF(跨站点请求伪造)令牌时,可能会发生此错误。这个令牌是一种安全措施,通过确保对服务器的请求是合法的,有助于防止恶意攻击。

我想到的解决办法似乎太简单了,但很有效。进入/tree即Jupyter主页并刷新浏览器。工作。

当使用Jupyter Lab时,投票最多的答案似乎不起作用。然而,这一个确实如此。只需将url复制到一个新标签中,将'lab'替换为'tree',然后按enter键加载页面。它将为您的会话生成一个新的csrf令牌,您就可以开始了!

我建议在默认情况下启用设置>自动保存文档,以避免担心将来丢失工作。它会定期保存,所以在任何超时发生之前,所有内容都应该是最新的。

我不需要打开一个新的笔记本。相反,我重新打开树,并重新连接内核。在某个时刻,我还重新启动了内核。- user650654 10月9日'19 at 0:17

对于任何在AWS Sagemaker上使用jupyterlab的人来说,复制标签就足以解决这个问题。