質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
87.20%
LibreOffice Calc

LibreOffice Calcは、様々なOSで利用可能なオフィススイートであるLibreOfficeに含まれるオープンソースの表計算ソフトです。テンプレートや背景色、枠線といった書式設定の各項目を柔軟で設定することができます。

PDF

PDF(Portable Document Format)とはISOによって国際標準として制定されている電子ドキュメント用の拡張子です。

PHP

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

解決済

phpからサーバー側にあるPDFをクライアント側にダウンロードもしくは添付送信したいが全て開かなくなる(破損)してしまう

kou___chan
kou___chan

総合スコア5

LibreOffice Calc

LibreOffice Calcは、様々なOSで利用可能なオフィススイートであるLibreOfficeに含まれるオープンソースの表計算ソフトです。テンプレートや背景色、枠線といった書式設定の各項目を柔軟で設定することができます。

PDF

PDF(Portable Document Format)とはISOによって国際標準として制定されている電子ドキュメント用の拡張子です。

PHP

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

2回答

0評価

1クリップ

402閲覧

投稿2021/12/04 13:01

編集2021/12/06 00:17

下記からExcelの雛形へ追記後、PDF化して保存

php

$soffice = '***************/tool/LibreOffice/program/soffice.exe'; $command ="$soffice --headless --convert-to pdf --outdir **************/text/save/kanridaityou/pdf $orderNote"; // echo $command, PHP_EOL; exec($command, $out, $ret);

上記の時点でExcel、PDFともに正常に開きます。
※ファイル名はkanridaityou+社員名(日本語).pdfもしくは.xlsx

画面が切り替わり下記の画像が表示されて、
保存ボタン→PCや携帯端末へダウンロード、閲覧
添付送信ボタン→PDF添付して送信処理
イメージ説明

実は昨日夜中には
添付送信(添付ファイルも正常に閲覧可)でしたし、
保存(PCにてダウンロード→閲覧可)でした。
強いてできなかったのが携帯へダウンロードはできましたが関連付けができていなかったのか、
clickしても開きませんでした。
こちらについては実際あるPDFファイルをクリックすると閲覧できました。

しかし本日は下記の様に閲覧ができない状態です。
イメージ説明
イメージ説明
コード1は下記(保存)となります

php

//ファイル名 // $fileName2 = $filefolder.$fileName . '.pdf'; $fileName2 = 'kanridaityou'.$fileName . '.pdf'; // PDFファイルの読み込みと表示部分 $path = __DIR__ . "/text/save/kanridaityou/pdf/$fileName2"; // $path = __DIR__ . "/text/save/$filefolder/pdf/$fileName2"; if (!preg_match('/\A\S+?/\S+/', $path)) { $path = 'application/octet-stream'; } header('Content-Type: ' . $path); header('X-Content-Type-Options: nosniff'); //-- ダウンロードファイルのサイズ header("Content-Transfer-Encoding: Binary"); header('Content-Length: ' . filesize($path)); header('Content-Disposition: inline; filename="' . basename($path) . '"'); // header('Content-Disposition: inline; filename="'.$fileName2.'"'); // ファイルを読み込んで出力 readfile($path); exit;

添付送信についてもコードは同じようなものを使用して、
modelへ投げて送信しており、正常にPDFの添付はされて送信しますが、閲覧はできません

ファイル名の日本語が駄目だと思い、色々付けましたがうまくいきませんでした。
1.日本語を使用せずアルファベット
2.MB_converterの様なものでUTF8やSHIFT_JSなど

LibreOfficeにてExcel追記とPDF化したものについてはアルファベット+日本語名で作成しておりますが、
閲覧は正常にできます

やりたいことはサーバー側に保存したPDFを正常に閲覧可能状態でダウンロードと添付送信をおこないたいです。

宜しくお願いいたします

追記…
ちなみにgoogle chromeのダウンロード履歴を見ると
file:///C:/Users/user/Desktop/kanridaityou%E5%BB%A3%E5%B********************.pdf

このな感じで日本語である社員名だけ記号などの羅列になっております
この辺の変換の問題でしょうか

動作環境は以下です。
サーバー windows server 2012
php7
mysql

クライアント Windows 10
PHP 7

宜しくお願いいたします

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

CHERRY

2021/12/06 00:38

Chrome のデベロッパーツールで、ダウンロード時のHTTPヘッダーを確認するとどのようなHTTPヘッダーになっていますか?
kou___chan

2021/12/06 07:23

CHERRY様 ご連絡ありがとうございます デベロッパは使ったことはあるのですがヘッダーの確認方法が無知で申し訳ありませんがわかりません。 ちなみに正常に処理(現在)の場合、chromeの右上の設定の履歴から確認すると通常のyamadataro.pdf となっておりますが エラーの際の履歴は %e5…….pdf となっており日本語の部分がおかしくなっておりました

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

LibreOffice Calc

LibreOffice Calcは、様々なOSで利用可能なオフィススイートであるLibreOfficeに含まれるオープンソースの表計算ソフトです。テンプレートや背景色、枠線といった書式設定の各項目を柔軟で設定することができます。

PDF

PDF(Portable Document Format)とはISOによって国際標準として制定されている電子ドキュメント用の拡張子です。

PHP

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