PHP で Excel をエクスポートする際の 500 エラーの解決策: [PHPExcel_Settings::setCacheStorageMethod()] メソッドを使用して、キャッシュ メソッドをパラメータとしてメソッドに渡し、キャッシュを設定します。
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_in_memory; PHPExcel_Settings::setCacheStorageMethod($cacheMethod);
PHPExcel_CachedObjectStorageFactory::cache_in_memory;
PHPExcel_CachedObjectStorageFactory::cache_in_memory_serialized;
PHPExcel_CachedObjectStorageFactory::cache_in_memory_gzip;
PHPExcel_CachedObjectStorageFactory::cache_to_discISAM;
PHPExcel_CachedObjectStorageFactory::cache_to_phpTemp;
$cacheMethod = PHPExcel_CachedObjectStorageFactory:: cache_to_phpTemp; $cacheSettings = array(’memoryCacheSize’ => ’8MB’ ); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings); php://temp文件在脚本结束是会自动删除。
PHPExcel_CachedObjectStorageFactory::cache_to_apc;
Php コード:
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_APC; $cacheSettings = array(’cacheTime’ => 600 ); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
スクリプトが終了すると、すべてのデータは APC からクリアされ (キャッシュ時間を無視)、このメカニズムを永続的なキャッシュとして使用することはできません。
=========================================== == ===============
Php コード:
PHPExcel_CachedObjectStorageFactory::cache_to_memcache
cache_to_memory を使用すると、セル オブジェクトは memcache に保存され、インデックスのみが保存されます。記憶の中で。デフォルトでは、PHPExcel はローカルホストとポート 11211 で memcache サービスを検索します。タイムアウトは 600 秒です。他のサーバーまたは他のポートで memcache サービスを実行する場合は、初期化中に変更できます:
Php code:
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_memcache; $cacheSettings = array( ’memcacheServer’ => ’localhost’, ‘memcachePort’ => 11211, ‘cacheTime’ => 600 ); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
初期化設定の観点から見ると、MS は複数の memcache サーバーのポーリング方法をまだサポートしていません。これは残念です。
スクリプトが終了すると、すべてのデータが memcache からクリアされます (キャッシュ時間は無視されます)。このメカニズムは永続ストレージには使用できません。
=========================================== == ===============
PHP コード:
PHPExcel_CachedObjectStorageFactory::cache_to_wincache;
使用cache_towincache方式,单元格对象会保存在Wincache中,只在内存中保存索引,默认情况下Wincache过期时间为600秒,对绝大多数应用是足够了,当然也可以在初始化时修改:
Php代码:
$cacheMethod = PHPExcel_CachedObjectStorageFactory::cache_to_wincache; $cacheSettings = array(’cacheTime’ => 600); PHPExcel_Settings::setCacheStorageMethod($cacheMethod, $cacheSettings);
PHPExcel还是比较强大的,最大的问题就是内存占用的问题,PHPExcel啥时候能出一个轻量级的版本,不需要那么多花哨的功能,只需要导出最普通的数据的版本就好了!
推荐学习:php培训
以上がPHP で Excel をエクスポートするときに 500 エラーが発生した場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。