🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

2回答

1468閲覧

EC2上でPHPを使ってcsvファイルを読み込みたいです。

amaturePy

総合スコア131

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Amazon EC2

Amazon EC2は“Amazon Elastic Compute Cloud”の略称です。Amazon Web Services(AWS)の一部であり、仮想化されたWebサーバーのコンピュータリソースをレンタルできるサービスです。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2019/12/02 04:22

編集2019/12/02 04:40

EC2内に設置したPHPファイルからcsvファイルの情報を読み込みたいです。
グローバルIPをブラウザ上で打つとPDOの接続ではエラー文が出ないので、DBへは接続できてると思うのですが、
csvファイルの読み込みのためのコードを追加するとエラー(HTTP ERROR 500)で読み込みができません。
ファイルの読み込みには読み込みが早いと聞いたのでSplFileObject関数を使用してます。
アドバイス頂けたら幸いです。

<?php try { $file = new SplFileObject('/home/ec2-user/winneyuser.csv',r); $file->setFlags(SplFileObject::READ_CSV); }catch (RuntimeException $e) { throw $e; } try { $pdo = new PDO( 'mysql:dbname=DBname;host=database-1.cuiejdfzi0uf.ap-northeast-1.rds.amazonaws.com;charset=utf8mb4', 'username', 'pass', [ PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, ] ); } catch(PDOException $e) { header('Content-Type: text/plain; charset=UTF-8', true, 500); exit($e->getMessage()); } header('Content-Type: text/html; charset=utf-8'); コード

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2019/12/02 04:31

「思う」では誰も問題切り分けができませんので、確実にしてください。 プログラムは書いたようにしか動かないので、true/falseの二択しかありません。
amaturePy

2019/12/02 04:40

失礼しました! BDへの接続はできてます!
m.ts10806

2019/12/02 05:08

DBのことですよね。 どのように確認したのでしょうか。
amaturePy

2019/12/02 05:50

はい。 まずはPDOだけでDBに接続できるかどうかのみデバックしながら試した形になります。 また成功時と違うログイン情報をコードに加えてアクセスエラーが出ることも確認しました。
guest

回答2

0

new SplFileObject('/home/ec2-user/winneyuser.csv',r); コード

上記の-rを削除することで解決しました!

投稿2019/12/02 08:24

amaturePy

総合スコア131

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

とりあえず、CSVの読み込みにDB操作は関係無いので、最小限のコードで実行してみては?

  • 何らかのフレームワークを使っている場合は、まずはフレームワークの外で最小限のコードを実行してから、フレームワークに組み込むことを考えると問題の切り分けが楽になります。

まずはこの部分以外のソースを全部消して

PHP

1<?php 2try { 3 $file = new SplFileObject('/home/ec2-user/winneyuser.csv',r); 4 $file->setFlags(SplFileObject::READ_CSV); 5}catch (RuntimeException $e) { 6 throw $e; 7}

PHPマニュアル
を参考にして、エラー表示とCSV読み込み用のコードを追加して、エラーを読みながら対応すれば、最小限のコードは出来ると思います。

PHP

1<?php 2 3//開発中は常にエラー表示を指定する 4ini_set('display_errors',1); 5error_reporting(E_ALL); 6 7try { 8 $file = new SplFileObject('/home/ec2-user/winneyuser.csv',r); 9 $file->setFlags(SplFileObject::READ_CSV); 10//この辺にCSV読み込み/表示用のコードを追加 11 12}catch (Exception $e) { 13 //例外をその場で表示する 14 echo $e->getMessage(); 15 echo PHP_EOL; 16 echo $e->getTraceAsString(); 17 exit(); 18} 19 20

既存環境に影響させずに最小限のコードを確認する方法

ソースコードは/home/ec2-user/read_csv.phpとかにおいて、
sshでログインしてからphp /home/ec2-user/read_csv.phpとすればフレームワークやApacheの設定に関係無く最小限のコードが実行出来るので、まずはそこからスタートするとデバッグが楽にできます。

投稿2019/12/02 05:04

tanat

総合スコア18727

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

amaturePy

2019/12/02 06:23

ありがとうございます。 確かにDB接続コードと混ぜる必要はないですね。 ファイルの読み取りのコードだけでも上手くいかないので、再度別の関数も試して見ます。 環境に関するアドバイスとても参考になります!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問