在用PHPexcel操作excel的时候,在本地是好使的,但是把代码部署到sae就不好使了。会遇到如下问题:

文件的操作被拒绝。

这个原因就是sae上的应用文件是不允许改动的。sae提供的文件方案是使用storage,所以可以把文件存储在storage来进行操作。

具体解决可以如下:

我在sae应用里新建一个domain域files(这个名字必须是小写字母或数字,如果是大写字母的话虽然可以在Cyberduck上新建成功,在domain管理里看到,但是是无效的domain)。在这个files下新建文件夹Files,然后把要操作的excel上传。

如上。

我对excel的操作代码如下:

 $file_name="Files/info.xls";

 $objPHPExcel=PHPExcel_IOFactory::load($file_name);

 $objPHPExcel->setActiveSheetIndex(0);

 $row=$objPHPExcel->getActiveSheet()->getHighestRow()+1;

 $objPHPExcel->getActiveSheet()->SetCellValue('A'.$row,$_POST['inputName']);

 $objPHPExcel->getActiveSheet()->SetCellValue('B'.$row,$_POST['inputClass']);

 $objPHPExcel->getActiveSheet()->SetCellValue('C'.$row,$_POST['inputEmail']);

 $objPHPExcel->getActiveSheet()->SetCellValue('D'.$row,$_POST['inputJob']);

 $objPHPExcel->getActiveSheet()->SetCellValue('E'.$row,$_POST['inputTel']);

 $objWriter=newPHPExcel_Writer_Excel5($objPHPExcel);

 $objWriter->save($file_name);

执行的是在info.xls的末尾添加一行。

修改之后的代码如下;

 $file_name='saestor://files/Files/info.xls';

 $objPHPExcel=PHPExcel_IOFactory::load($file_name);

 $objPHPExcel->setActiveSheetIndex(0);

 $row=$objPHPExcel->getActiveSheet()->getHighestRow()+1;

 $objPHPExcel->getActiveSheet()->SetCellValue('A'.$row,$_POST['inputName']);

 $objPHPExcel->getActiveSheet()->SetCellValue('B'.$row,$_POST['inputClass']);

 $objPHPExcel->getActiveSheet()->SetCellValue('C'.$row,$_POST['inputEmail']);

 $objPHPExcel->getActiveSheet()->SetCellValue('D'.$row,$_POST['inputJob']);

 $objPHPExcel->getActiveSheet()->SetCellValue('E'.$row,$_POST['inputTel']);

 $objWriter=newPHPExcel_Writer_Excel5($objPHPExcel);

 $objWriter->save($file_name);

可以看到,修改的只是文件路径。然后操作就完全没有问题了。

问题解决了,接下来我要扯扯怎么找到的办法。

刚开始说要用storage,好,我就去sae官网看storage文档,结果,说的什么鬼,没有收获。

毕竟我要找的重点是storage文件的存储路径,文档里说的是整个元素级的处理。

只有一句:

这个还是在介绍文档里说的。

既然如此,我就先上传文件来试试呗。域和文件结构已建好。代码参考:http://cloudbbs.org/forum.php?mod=viewthread&tid=23708里的7楼作者回答。

上传文件代码如下:

 <metacharset="UTF-8"/>

 <formaction=""method="post"enctype="multipart/form-data">

 <inputtype="file"name="file"/>

 <inputtype="submit"/>

 </form>

 <?php

 if($_FILES['file']!='')

 {

 $storage=newSaeStorage();

 $domain='files';

 $dest='Files/'.$_FILES['file']['name'];

 $src=$_FILES["file"]["tmp_name"];

 $storage->upload($domain,$dest,$src);

 $url=$storage->getUrl($domain,$dest);

 echo"网址:$url<br/><imgsrc='$url'/>";

 }

 ?>

可以看到返回的地址是:http://dutcircle-files.stor.sinaapp.com/Files/实验.png

在应用管理里也可以看到文件是已经上传好了的。

再尝试打开下:

 <metacharset="UTF-8"/>

 <formaction=""method="post">

 <inputtype="text"name="text"/>

 <inputtype="submit"/>

 </form>

 <?php

 if($_POST['text']!='')

 {

 $storage=newSaeStorage();

 $domain='files';

 $dest='Files/'.$_POST['text'];

 $url=$storage->getUrl($domain,$dest);

 echo"网址:$url<br/><imgsrc='$url'/>";

 }

可以看到,可以通过这个url来获取文件。

但是,直接把这个url用来操作excel,

 $objExcel=newPHPExcel();

 $storage=newSaeStorage();

 $domain='files';

 $dest='Files/info.xls';

 $url=$storage->getUrl($domain,$dest);

 $file_name=$url;

 //http://dutcircle-files.stor.sinaapp.com/Files/info.xls

 $file_name='saestor://files/Files/info.xls';

 $objPHPExcel=PHPExcel_IOFactory::load($file_name);

是不对的,会报错,找不到这个文件。

所以得换个方法,http://saebbs.com/forum.php?mod=viewthread&tid=9456

虽然提的问题和我不一样,但人家已经解决了我的问题。

修改代码,至此,大功告成。

PHPExcel操作sae的storage上的文件的更多相关文章

  1. SAE利用storge上传文件 - myskies的专栏 - 博客频道 - CSDN.NET

    SAE利用storge上传文件 - myskies的专栏 - 博客频道 - CSDN.NET SAE利用storge上传文件

  2. Go连接到Linux服务器进行操作-执行shell命令&&上传文件

    Go连接到Linux服务器进行操作 使用密码连接Linux服务器 package main import ( "fmt" "golang.org/x/crypto/ssh ...

  3. Python脚本控制的WebDriver 常用操作 <二十六> 上传文件

    测试用例场景 上传文件的方法是找到上传文件的对象,通常是的对象.然后直接往这个对象send_keys,传入需要上传文件的正确路径.绝对路径和相对路径都可以,但是上传的文件必须存在,否则会报错. Pyt ...

  4. hadoop的hdfs文件操作实现上传文件到hdfs

    这篇文章主要介绍了使用hadoop的API对HDFS上的文件访问,其中包括上传文件到HDFS上.从HDFS上下载文件和删除HDFS上的文件,需要的朋友可以参考下hdfs文件操作操作示例,包括上传文件到 ...

  5. hadoop的API对HDFS上的文件访问

    这篇文章主要介绍了使用hadoop的API对HDFS上的文件访问,其中包括上传文件到HDFS上.从HDFS上下载文件和删除HDFS上的文件,需要的朋友可以参考下hdfs文件操作操作示例,包括上传文件到 ...

  6. Ui自动化测试上传文件方法都在这里了

    前言 实施UI自动化测试的时候,经常会遇见上传文件的操作,那么对于上传文件你知道几种方法呢?今天我们就总结一下几种常用的上传文件的方法,并分析一下每个方法的优点和缺点以及哪种方法效率,稳定性更高 被测 ...

  7. SAE上传文件到storage

    还有什么比代码更清晰的讲解 html代码: 一定需要下面这个: method="post" enctype="multipart/form-data" < ...

  8. 【Azure Developer】VS Code运行Java 版Azure Storage SDK操作Blob (新建Container, 上传Blob文件,下载及清理)

    问题描述 是否可以用Java代码来管理Azure blob? 可以.在代码中加入azure-storage-blob依赖.即可使用以下类操作Azure Storage Blob. BlobServic ...

  9. Sae 上传文件到Storage

    首先说一下几个地方: 1.上传使用ss.upload("domin域名","源地址","目标地址,也就是storage的地址");假设要上传 ...

随机推荐

  1. [ActionScript 3.0] AS3 获取某年某月的天数(Get number of days in a month)

    function getNumberOfDays($year:int, $month:int):int { var month:Date = new Date($year, $month + 1, 0 ...

  2. php mssql 中文各种乱码

    1 查询输出时乱码  (SELECT ) 因为MSSQL 数据库一般都是 GBK 编码,所以在php页面中加入 header('Content-Type:text/html; charset=GBK' ...

  3. AngularJs在单击提交后显示验证信息.

    <!DOCTYPE html> <html ng-app="app"> <head> <meta charset="utf-8& ...

  4. ppm与mg/m3转换

    http://wenku.baidu.com/link?url=PY0Nb09VWmBDZgLvMhaHYGJyaC6YcdYAI5XTPRkxMpDHPrs3dNxskYkKmp2F0E6Sl2H5 ...

  5. sql server 2008 r2 中的oracle发布使用笔记

    sql server 2008 r2 中的oracle发布功能,能够将oracle数据库作为发布服务器,将oracle中的数据自动同步到sql server 数据库中,在新建oracle发布前确保sq ...

  6. Android——inflate 将一个xml中定义的布局找出来

    通俗的说,inflate就相当于将一个xml中定义的布局找出来. 因为在一个Activity里如果直接用findViewById()的话,对应的是setConentView()的那个layout里的组 ...

  7. [转]iOS技巧之获取本机通讯录中的内容,解析通讯录源代码

    一.在工程中添加AddressBook.framework和AddressBookUI.framework 二.获取通讯录 1.在infterface中定义数组并在init方法中初始化 ? 1 2 3 ...

  8. 关于scrollview监听的一些方法

    一 package cn.testscrollview; import android.os.Bundle; import android.view.MotionEvent; import andro ...

  9. String 去重,区分大小写

    题目要求:去除,和.,相同的单词去除后面的.区分大小写 示例:输入:There is a will,there is a way. 输出There is a will there way 答案代码: ...

  10. MCADEx Tools 6.3下载地址

    MCADEx Tools 6.3下载地址: http://pan.baidu.com/s/1pLxQPkR 修改参数批量设置工具为模型批量检查工具; 修改模型批量检查过滤工具; 修改工程图管理过滤工具 ...