phpspreadsheet密码保护

问题描述 投票:1回答:2

使用phpspreadsheet

有没有办法用密码保护Excel工作表,以便用户无法在没有密码的情况下阅读?

我知道你可以保护单元格或工作表不被写入,但我正在寻找一种方法来保护整个文件不被打开,一旦用户打开它,它将弹出“输入密码”屏幕

excel passwords phpspreadsheet
2个回答
1
投票

在电子表格上设置安全性

Excel提供3个级别的“保护”:

  1. 文档:允许您在完整的电子表格上设置密码,只允许在输入密码时进行更改。
  2. 工作表:提供其他安全选项:您可以禁止在特定工作表上插入行,禁止排序,...
  3. 单元格:提供锁定/解锁单元格以及显示/隐藏内部公式的选项。设置文档安全性的示例: $spreadsheet->getSecurity()->setLockWindows(true); $spreadsheet->getSecurity()->setLockStructure(true); $spreadsheet->getSecurity()->setWorkbookPassword("PhpSpreadsheet");

设置工作表安全性的示例:

   $spreadsheet->getActiveSheet()->getProtection()->setPassword('PhpSpreadsheet');
   $spreadsheet->getActiveSheet()->getProtection()->setSheet(true);
   $spreadsheet->getActiveSheet()->getProtection()->setSort(true);
   $spreadsheet->getActiveSheet()->getProtection()->setInsertRows(true);
   $spreadsheet->getActiveSheet()->getProtection()->setFormatCells(true);

设置单元安全性的示例:

$spreadsheet->getActiveSheet()->
getStyle('B1')->
getProtection()->
setLocked(\PhpOffice\PhpSpreadsheet\Style\Protection::PROTECTION_UNPROTECTED);

如果您需要任何工作表保护功能,请确保启用工作表保护!这可以使用以下代码完成:

$spreadsheet->getActiveSheet()->getProtection()->setSheet(true);

-1
投票

在Excel 2016上(里程可能因版本而异)

打开电子表格,然后转到:

  • 文件>
  • 信息>
  • 保护工作簿>使用密码加密

并输入密码,这将在打开时提示用户。

© www.soinside.com 2019 - 2024. All rights reserved.