php 生成excel文件 并压缩成zip包加密

生成excel用的composer包  composer require phpoffice/phpword 0.18.0

生成zip用的composer包   composer require gemorroj/archive7z

<?php

namespace app\controller;

use Archive7z\Archive7z;
use http\Exception\RuntimeException;
use PhpOffice\PhpSpreadsheet\IOFactory;
use PhpOffice\PhpSpreadsheet\Spreadsheet;

class zip
{
    public static function excelFile()
    {
        $data = [['id' => 1, 'name' => '张三'], ['id' => 2, 'name' => '李四'], ['id' => 3, 'name' => '王五']];

        $title = array('班级', '姓名');
        $spreadsheet = new Spreadsheet();
        $worksheet = $spreadsheet->getActiveSheet()->setTitle('sheet1');

        // $writer = new Xlsx($spreadsheet);
        //表头
        //设置单元格内容
        foreach ($title as $key => $value) {
            $worksheet->setCellValueByColumnAndRow($key + 1, 1, $value);
        }

        $row = 2; //第二行开始
        foreach ($data as $item) {
            $column = 1;
            foreach ($item as $value) {
                $worksheet->setCellValueByColumnAndRow($column, $row, $value);
                $column++;
            }
            $row++;
        }

        # 保存为xlsx
        $filename = 'VoteExcel.xls';
        $filePath = root_path() . 'public/uploads/' . $filename;

        $writer = IOFactory::createWriter($spreadsheet, 'Xls');

        $writer->save($filePath);
        # 浏览器下载
        header('Content-Type:application/vnd.ms-excel');
        header('Content-Disposition:attachment;filename="' . $filename . '"');
        header('Cache-Control:max-age=0');

        $writer->save('php://output');

        return $filePath;
    }


    public static function zipFile()
    {
        $encipterFile = self::excelFile();

        $filename = "test.zip";
        $zip = new \ZipArchive();
        if ($zip->open($filename, \ZipArchive::CREATE | \ZipArchive::OVERWRITE) === true) {
            //设置密码 注意此处不是加密,仅仅是设置密码
            if (!$zip->setPassword('password')) {
                throw new RuntimeException('Set password failed');
            }
            $zip->addFile($encipterFile, $encipterFile);//            //往压缩包内添加文件
            if ($zip->setEncryptionName($encipterFile, \ZipArchive::EM_AES_256)) {       //加密文件 此处文件名及路径是压缩包内的
                throw new RuntimeException('Set encryption failed');
            }
        }
        $zip->close(); //关闭压缩包
    }

}

在框架中全局搜索 test.zip 即可查看完美效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
可以使用Java中的DOM和ZipOutputStream来实现将字符串生成xml文件压缩成zip的功能。以下是一个简单的实现示例: ```java import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.File; import java.io.FileOutputStream; import java.util.zip.ZipEntry; import java.util.zip.ZipOutputStream; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; public class XmlZipper { public static void main(String[] args) throws Exception { // 生成xml字符串 String xmlString = "<root><message>Hello World!</message></root>"; // 将xml字符串转换为Document对象 DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse(new ByteArrayInputStream(xmlString.getBytes())); // 创建zip文件 File zipFile = new File("example.zip"); ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile)); // 将xml写入zip文件 ZipEntry xmlEntry = new ZipEntry("example.xml"); zipOut.putNextEntry(xmlEntry); ByteArrayOutputStream xmlOut = new ByteArrayOutputStream(); document.setXmlStandalone(true); document.normalize(); document.getDocumentElement().normalize(); XmlUtils.writeXml(document, xmlOut); zipOut.write(xmlOut.toByteArray()); xmlOut.close(); zipOut.closeEntry(); // 关闭zip文件 zipOut.finish(); zipOut.close(); } public static class XmlUtils { public static void writeXml(Document document, ByteArrayOutputStream out) throws Exception { javax.xml.transform.TransformerFactory tf = javax.xml.transform.TransformerFactory.newInstance(); javax.xml.transform.Transformer transformer = tf.newTransformer(); transformer.setOutputProperty(javax.xml.transform.OutputKeys.ENCODING, "UTF-8"); transformer.setOutputProperty(javax.xml.transform.OutputKeys.INDENT, "yes"); javax.xml.transform.dom.DOMSource source = new javax.xml.transform.dom.DOMSource(document); javax.xml.transform.stream.StreamResult result = new javax.xml.transform.stream.StreamResult(out); transformer.transform(source, result); } } } ``` 这段代码将生成一个名为example.zip压缩文件,并在其中含了一个名为example.xml的xml文件。你可以使用ZipFile类来解压缩该文件,并读取其中的xml内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一分半心动

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值