การนำภาพที่เป็น base64 มาใส่ใน TCPDF ใส่เท่าไรก็ไม่ได้สักที
ตอนนี้พยายามเท่าไร ก็ไม่มีรูปใน pdf ซักที ใครพอมีวิธีแก้ไหมคะ
Code (PHP)
<?php
require_once('tcpdf/tcpdf.php');
$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
// remove default header/footer
$pdf->setPrintHeader(false);
$pdf->setPrintFooter(false);
// set font
$pdf->SetFont('thsarabun', '', 13);
// add a page
$pdf->AddPage();
// -----------------------------------------------------------------------------
mysql_connect("localhost", "root", "") or die("Error connecting to database: ".mysql_error());
mysql_select_db("TDASampleY") or die(mysql_error());
mysql_query("SET NAMES UTF8");
$tbl = '
<table cellpadding="2" cellspacing="2" >
<tr style="background-color:#666666;color:#FFFFFF;font-size:1.5em;" align = "center">
<th colspan="9" >ข้อมูลบัตรประชาชน</th>
</tr>
<tr style="background-color:#999999;color:#ffffff;font-size:1em; font-weight: bold;" align = "center">
<td>ID</td>
<td>NID</td>
<td>Name</td>
<td>surname</td>
</tr>';
$aar = $_POST["chk"];
$com_id = implode(",", $aar);
for($i=0;$i<count($_POST["chk"]);$i++)
{
if(trim($_POST["chk"][$i]) != "")
{
$sql = "SELECT * from ThaiIDCard Where id IN ($com_id) order by id";
}
else {
$sql = "SELECT * from ThaiIDCard order by id";
}
}
if ($sql==""){
$sql = "SELECT * from ThaiIDCard order by id";
}
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
$tbl.=' <tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>'.'<img height="100" src="data:image/;base64,' . $result["photo"] . '"/>'.'</td>
</tr>';
}
$tbl.='</table>';
// output the HTML content
$pdf->writeHTML($tbl, true, false, true, false, '');
//Close and output PDF document
$pdf->Output('ThaiIDCloud.pdf', 'I');
// -----------------------------------------------------------------------------
Tag : PHP
Date :
2019-01-31 10:14:55
By :
yanikanaja
View :
4081
Reply :
27
Copy เค้ามา ลองดูละกันครับ
You cannot use base64 stream in src rather first save the stream to a file then use it
$img_base64_encoded = '...';
$imageContent = file_get_contents($img_base64_encoded);
$path = tempnam(sys_get_temp_dir(), 'prefix');
file_put_contents ($path, $imageContent);
$img = '<img src="' . $path . '">';
$pdf->writeHTML($img, true, false, true, false, '');
Date :
2019-01-31 10:51:23
By :
arm8957
ถ้าเปลี่ยนใจทัน เก็บ path ชื่อไฟล์ เก็บรูปในโฟลเดอร์ ใช้ก็ดึงมาง่ายกว่าครับ
Date :
2019-01-31 13:00:25
By :
apisitp
ไม่ต้องแก้หรอกครับ แบบนั้น น่ะดีแล้่ว security ดีกว่าทำเป็น ไฟล์ ถ้าพนักงานไว้ใจไม่ได้ แย่เลย เอารูปเขาไปทำอะไรก็ไม่รู้ได้
แล้ว แสดงภาพหรือยัง ก็ตาม 1 เลยครับ เพราะที่ขาดไป คือ image/typeimage;
และ $result["photo"] เป็น base64 หรือเปล่า viewsource ดูข้อมูล จาก browser ว่าถูกต้องไหม
Date :
2019-02-04 13:01:53
By :
Chaidhanan
Code (PHP)
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
//$imgdata = base64_decode("'".$result["photo"]."'");
$img_base64_encoded = 'data:image/typeimage;base64,'.$result["photo"];
$imageContent = file_get_contents($img_base64_encoded);
$path = tempnam(sys_get_temp_dir(), 'prefix');
file_put_contents ($path, $imageContent);
$img = '<img src="' . $path . '">';
$tbl.=' <tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>'.$img.'</td>
</tr>';
//$pdf->Image('@'.$imgdata);
}
$tbl.='</table>';
ลองทำแบบนี้แล้วค่ะ ภาพก็ยังไม่ขึ้นอยู่ดี
ส่วนCode (PHP)
$imgdata = base64_decode("'".$result["photo"]."'");
$pdf->Image('@'.$imgdata);
ถ้าใช้โค้ดนี้ภาพขึ้นค่ะ แต่เอามาวนลูปไม่ได้
Date :
2019-02-05 17:21:30
By :
yanikanaja
typeimage = jpg หรือ bmp หรือ png หรือ gif
โอ้ยกลั้นหัวเราะแทบไม่ไหว อุตส่าห์มาร์คสีแดง ก็ยังไม่เข้าใจ
ตอนนี้เข้าใจแจ่มชัดเลย ทำไม พวก ป.เอก ถีงสอน เด็กประถม ไม่ค่อยรู้เรื่อง
ปล. กรรม แก้โค๊ดหลายรอบ เลย
อัลกอลิธึม ไม่ถูกเลย วาง code ไม่ถูกต้อง
อันนี้ควรจะได้
Code (PHP)
$imgdata = base64_decode("'".$result["photo"]."'");
$src = 'data:image/png;base64,'.$imgdata;
$img = '<img src="' . $src . '">';
ประวัติการแก้ไข 2019-02-05 17:47:05 2019-02-05 17:47:37 2019-02-05 17:50:07 2019-02-05 17:51:22 2019-02-05 17:54:01 2019-02-05 17:56:28
Date :
2019-02-05 17:45:24
By :
Chaidhanan
เอาโค๊ดที่แก้ไขแล้วมาดูด้วยครับ จะได้รู้ว่าผิดตรงไหน
Date :
2019-02-06 00:01:49
By :
Chaidhanan
https://stackoverflow.com/a/54520065/128761
ลองดู อันนี้ได้ไหม?
อีกไอเดียนึงคือ <img src="image.php?id=xxx"> ให้มัน src ไปยังไฟล์ image.php แล้วไฟล์นี้ไปดึงข้อมูลภาพมาแสดงพร้อมทั้ง content-type ให้ถูกต้อง มันก็จะเหมือนลิ้งค์ไปยังไฟล์ภาพตรงๆ แต่ใช้ดึงข้อมูลภาพจาก db แทน.
Date :
2019-02-06 00:30:42
By :
mr.v
ลองใส่โค้ด แบบนี้ค่ะ
Code (PHP)
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
//$imgdata = base64_decode("'".$result["photo"]."'");
$imgdata = base64_decode("'".$result["photo"]."'");
$src = 'data:image/png;base64,'.$result["photo"];
$img = '<img src="' . $src . '">';
$tbl.=' <tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>'.$img.'</td>
</tr>';
$pdf->Image('@'.$imgdata);
}
$tbl.='</table>';
ผลลัพธ์ที่ได้ออกมาเป็นแบบนี้ค่ะ
ลองทำมา 3 วันยังไม่ได้ อยากจะร้องไห้ TT^TT
คำสั่ง
Code (PHP)
<td>'.$img.'</td>
ไม่มีรูปภาพออกมาเลย
ส่วนคำสั่ง
Code (PHP)
$pdf->Image('@'.$imgdata);
เอามาลองภาพขึ้นนะคะ แต่ขึ้นมาภาพแล้ว แล้วไม่ได้วนลูปในตารางที่ต้องการด้วย
ประวัติการแก้ไข 2019-02-06 14:57:56 2019-02-06 14:58:07 2019-02-06 14:58:15 2019-02-06 14:58:24 2019-02-06 14:58:32 2019-02-06 14:58:40 2019-02-06 14:58:49 2019-02-06 14:59:00 2019-02-06 14:59:08
Date :
2019-02-06 14:55:32
By :
yanikanaja
ลองอันนี้หรือยังครับ
Code (PHP)
$pdf->writeHTMLCell(0, 0, 0, 0, '<img src="'.$src.'" height="30mm" />');
Date :
2019-02-06 16:06:18
By :
nobetaking
Code (PHP)
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
//$imgdata = base64_decode("'".$result["photo"]."'");
$imgdata = base64_decode("'".$result["photo"]."'"); // ตัวแปร $imgdata ประกาศ แล้วทำไมไม่เอามาใช้
$src = 'data:image/png;base64,'.$result["photo"]; // เอา $imgdata มาใช้บันทัดนี้สิครับ $result['photo'] มันเป็น binary ไม่ใช่เหรอ
$img = '<img src="' . $src . '">';
$tbl.=' <tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>'.$img.'</td>
</tr>';
$pdf->Image('@'.$imgdata);
}
$tbl.='</table>';
คงไม่ต้องแก้ให้นะครับ บอกที่ผิดแล้ว เอาตัวแปรไปใช้ให้ถูกที่ถูกทาง มันก็ควรจะได้แล้ว
$pdf->Image('@'.$imgdata); คำสั่งนี้ script มันไม่ได้ใช้ร่วมกับ html เลิกสนใจมันไปได้เลย
เมื่อไหร่ที่อยากเขียนด้วยคำสั่ง pdf ล้วนๆ ค่อยมาสนใจมัน
Date :
2019-02-06 16:39:53
By :
Chaidhanan
ตอบความคิดเห็นที่ : 14 เขียนโดย : nobetaking เมื่อวันที่ 2019-02-06 16:06:18
รายละเอียดของการตอบ ::
ได้เป็นแบบนี้ค่ะ
Code (PHP)
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
//$imgdata = base64_decode("'".$result["photo"]."'");
$imgdata = base64_decode("'".$result["photo"]."'");
$src = 'data:image/png;base64,@'.$result["photo"];
$img = '<img src="' . $src . '">';
$tbl.=' <tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
</tr>';
}
$pdf->writeHTMLCell(0, 0, 0, 0, '<img src="'.$src.'" />');
$tbl.='</table>';
// output the HTML content
$pdf->writeHTML($tbl, true, false, true, false, '');
//Close and output PDF document
$pdf->Output('ThaiIDCloud.pdf', 'I');
Date :
2019-02-06 16:40:58
By :
yanikanaja
แก้ให้ครั้งสุดท้ายนะครับ ถ้ายังเอาอย่างอื่นผสมก็ลองต่อเอาเองนะครับ
Code (PHP)
$sqlQ = mysql_query($sql) or die ("Error Query [".$sql."]");
while($result = mysql_fetch_array($sqlQ)){
$tbl.='<tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td><td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td><td>'.$result["surnameT"].'</td>
<td><img src="data:image/png;base64,' . base64_decode($result['photo']) . '" ></td>
</tr>';
}
$tbl.='</table>';
จุดที่ผิด 1 สีแดงใส่เข้าไปทำไม
$imgdata = base64_decode("'". $result["photo"]."'" );
จุดที่ผิด 2 สีแดง ตัวแปรที่แปลงแล้วทำไมไม่นำมาใช้ แล้วมันจะได้อะไร
$src = 'data:image/png;base64,@'.$result["photo"];
จุดที่ผิด 3 สีแดง เป็นคำสั่ง ของ PDF ไม่เหมาะที่จะใส่ร่วมกับ tag html (ใส่ได้ แต่ โครงสร้างจะเพี้ยน หรือ เกิด error หรือจัด layout ยาก)
$pdf->writeHTMLCell(0, 0, 0, 0, '<img src="'.$src.'" />');
$tbl.='</table>';
Date :
2019-02-06 17:14:06
By :
Chaidhanan
ตอนนี้เหมือนใครแนะนำอะไรไป แต่ผู้ถามไปคนละทางกับผู้แนะนำ แถมตอบมาคนละเรื่อง
ผมว่าผู้ถามยังแยกไม่ออกว่า PHP HTML ทำงานออกมาแบบไหน
แล้วจะแปลงเป็น PDF เลยเอา code มาปนกันไปหมด แนะนำแบบนี้
ลองสร้างหน้าเพจ ที่ต้องการนี้ ให้ออก มาเป็นรูปแบบ HTML จัดเรียงข้อมูลตามต้องการ
ถ้าสามารถทำเป็น HTML แล้วมันได้ตามต้องการ
ค่อยกลับมาว่ากันใหม่เรื่องทำเป็น PDF ดีกว่าครับ
แต่ถ้ามั่นใจก็แยกให้ออกว่า จะใส่ค่าที่ได้จากการดึงข้อมูลด้วยภาษา PHP ลงไปใน้ HTML อย่างไร
แล้วจะแปลง HTML ทั้งหมดไปเป็น PDF ได้อย่างไร...
ผมก็เคยติดปัญหา สั่ง writeHTML ตามด้วย tbl มันไม่ตอบโจทย์
ผมเลยใช้ EOD ยัดทุกอย่างลงไป เวลาใช้งาน มันตอบโจทย์และง่ายกว่าครับ
แค่แนะนำทางเลือกใหม่
ตย.เขียนโดยใช้ CI
<?php
$this->load->library('Tcpdfx');
// echo $get_teacher_name->id_teacher;
// $datafromdb = $this->sidebar_model->get_teacher_name($get_teacher_name->id_teacher);
// print_r($get_store);
class MYPDF extends TCPDF {
public $datafromdb;//<-- to save your data
function __construct( $datafromdb , $orientation, $unit, $format )
{
parent::__construct( $orientation, $unit, $format, true, 'UTF-8', false);
// echo $datafromdb;
// print_r($datafromdb);
// echo "<hr>";
$this->datafromdb = $datafromdb->teacherName;
//...
}
public function Header() {
// print_r($datafromdb);
// $image_file = 'http://council.buu.ac.th/image/LogoBuuThai.jpg';
$image_file = K_PATH_IMAGES.'buu.png';
$this->Image($image_file, 'C', 5, 25, '', 'PNG', false, 'C', false, 300, 'C', false, false, 0, false, false, false);
$this->SetFont('thsarabun', 'B', 18);
$this->Ln(33);
$this->Cell(0, 10, 'รายชื่อนิสิตที่ '.$this->datafromdb.' เป็นอาจารย์ที่ปรึกษาหลักควบคุมวิทยานิพันธ์', 0, false, 'C', 0, '', 0, false, 'M', 'M');
}
}
$pdf = new MYPDF($get_teacher_name,PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true,
'UTF-8', false);
$pdf->SetCreator(PDF_CREATOR);
$pdf->SetHeaderData(PDF_HEADER_LOGO, PDF_HEADER_LOGO_WIDTH, PDF_HEADER_TITLE, PDF_HEADER_STRING);
$pdf->setHeaderFont(Array(PDF_FONT_NAME_MAIN, '', PDF_FONT_SIZE_MAIN));
$pdf->setFooterFont(Array(PDF_FONT_NAME_DATA, '', PDF_FONT_SIZE_DATA));
$pdf->SetDefaultMonospacedFont(PDF_FONT_MONOSPACED);
// $pdf->SetMargins(PDF_MARGIN_LEFT, PDF_MARGIN_TOP, PDF_MARGIN_RIGHT);
$pdf->SetMargins(15, 45, 10, true);
$pdf->SetHeaderMargin(PDF_MARGIN_HEADER);
$pdf->SetFooterMargin(PDF_MARGIN_FOOTER);
$pdf->SetAutoPageBreak(TRUE, PDF_MARGIN_BOTTOM);
$pdf->setImageScale(PDF_IMAGE_SCALE_RATIO);
$pdf->SetFont('thsarabun', '', 14, '', true);
$pdf->AddPage('L', 'A4');
$tbl = <<<EOD
<style>
td{
border:1px solid #CCC;
}
</style>
<table cellspacing="0" cellpadding="1" border="0" style="width:950px;">
<thead>
<tr>
<td align="center" bgcolor="#F2F2F2" width="30">#</td>
<td align="center" bgcolor="#F2F2F2" width="180">ชื่อ-นามสกุล</td>
<td align="center" bgcolor="#F2F2F2" width="370">ภาษาไทย</td>
<td align="center" bgcolor="#F2F2F2" width="370">ภาษาอังกฤษ</td>
</tr>
</thead>
<tbody>
EOD;
foreach ($get_store as $key => $value) {
$num = $key+1;
$name = $value->arrTitle[0]->titleName.$value->arrNisitName[0]->nisitName;
if (empty($value->arrThesisName)) {
$thai = '-';
$eng = '-';
}else{
$thai = $value->arrThesisName[0]->thesisNameThai;
$eng = $value->arrThesisName[0]->thesisNameEng;
}
$tbl .= <<<EOD
<tr>
<td align="center" width="30">$num</td>
<td align="left" width="180"> $name</td>
<td align="left" width="370"> $thai</td>
<td align="left" width="370"> $eng</td>
</tr>
EOD;
if($num==6){
$tbl .= <<<EOD
</tbody></table>
EOD;
$pdf->writeHTML($tbl, true, false, false, false, '');
$pdf->lastPage();
$pdf->AddPage('L', 'A4');
$tbl = <<<EOD
<style>
td{
border:1px solid #CCC;
}
</style>
EOD;
$tbl .= <<<EOD
<table cellspacing="0" cellpadding="1" border="1" style="width:950px;">
<thead>
<tr>
<td align="center" bgcolor="#F2F2F2" width="30">#</td>
<td align="center" bgcolor="#F2F2F2" width="180">ชื่อ-นามสกุล</td>
<td align="center" bgcolor="#F2F2F2" width="370">ภาษาไทย</td>
<td align="center" bgcolor="#F2F2F2" width="370">ภาษาอังกฤษ</td>
</tr>
</thead>
<tbody>
EOD;
}
//
}
$tbl .= <<<EOD
</tbody></table>
EOD;
$pdf->writeHTML($tbl, true, false, false, false, '');
$pdf->Output('example_001.pdf', 'I');
?>
สุดท้าย
1.ลองทำเพจดึงค่า แสดงรูปแบบ html ปกติ ให้มันโ๙ว์รูปตามที่ต้องการให้ได้ก่อน
2.ค่อย ๆ มอง code ว่าจะจับ html จาก ข้อ 1 มายัด แปลง ประยุกต์ อย่างไรให้เข้ากับปลั๊กอิน PDF ที่ใช้
Date :
2019-02-07 08:44:41
By :
apisitp
ถือว่าเป็นโพสที่พวกพี่ ๆและอาจารย์ให้ความสนใจและความช่วยเหลืออย่างมาก
อันนี้ผมลองทำครับ เผื่อเอาไปปรับเล่นดูอีกที
Code (PHP)
<?php
require_once('tcpdf.php');
$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8');
$pdf->setPrintHeader(false);
// เพิ่มฟ้อนต์ภาษาไทยเข้ามา ตัวธรรมดา กำหนด ชื่อ เป็น angsana
$pdf->AddFont('thsarabun','','thsarabun.php');
// กำหนดฟ้อนต์ที่จะใช้ อังสนา ตัวธรรมดา ขนาด 16
$pdf->SetFont('thsarabun','',16);
// เพิ่มหน้าเอกสาร
$pdf->AddPage();
$img = '<img src="img/kud.png" width="50">';
$data_array = array("พงศักษ", "สุนทร", "ประชะรียา", "ปะรมชัย");
$html = '<table width="400" border="1">';
foreach($data_array as $key ) {
$html .= '<tr>
<td>' . $img.$key . '</td>
</tr>';
}
$html .= '</table>';
//ระยะห่างด้านหลัง,ระยะห่างด้านล่าง,ระยะห่างด้านซ้าย,ระยะห่างด้านบน
$pdf->writeHTMLCell(0, 0, 0, 0,$html);
$pdf->Output('test.pdf', 'I');
?>
ผลลัพธ์
ปล.ผมแค่อยากทำให้มัน loop ภาพออกมาเฉย ๆนะครับ ตรงอื่นๆ ต้องปรับให้เหมาะสมอีกที
ประวัติการแก้ไข 2019-02-07 10:55:12
Date :
2019-02-07 10:51:27
By :
nobetaking
อย่างแรกเลยนะ html คุณไม่ถูก.
ตรงหัวตารางจะมี ID, NID, Name, Surname แต่ไม่มีคอลัมน์ของภาพ.
แต่ตรงภายใน loop ดันมีคอลัมน์ของภาพ.
แล้วตรงหัว ถ้าคอลัมน์ครบ ควรจะเป็น colspan="5" ไม่ใช่ยัดไปตั้ง 9.
แก้ตรงนี้ก่อนเลย.
แล้วนี่คือตัวอย่างที่ทดลองทำแล้วแสดงภาพนะครับ
Code (PHP)
<?php
// my data ---------------------------------------------------------
// ข้อมูลสมมุติ
$names = [
0 => [
'id' => '1',
'idnum' => '12345',
'nameT' => 'สมชาย',
'surnameT' => 'พวงหาย',
],
1 => [
'id' => '2',
'idnum' => '12346',
'nameT' => 'สมหวัง',
'surnameT' => 'ดังแน่มึง',
],
2 => [
'id' => '3',
'idnum' => '12347',
'nameT' => 'สมศรี',
'surnameT' => 'มีหู',
],
3 => [
'id' => '4',
'idnum' => '12348',
'nameT' => 'สมน้ำหน้า',
'surnameT' => 'ปากพาจน',
],
];
// ภาพสมมุติ
$images = [
'',
'',
'',
''
];
// end my data -----------------------------------------------------
require_once 'tcpdf/tcpdf.php';
$pdf = new TCPDF(PDF_PAGE_ORIENTATION, PDF_UNIT, PDF_PAGE_FORMAT, true, 'UTF-8', false);
// remove default header/footer
$pdf->setPrintHeader(false);
$pdf->setPrintFooter(false);
// set font
$pdf->SetFont('thsarabun', '', 13);
// add a page
$pdf->AddPage();
// -----------------------------------------------------------------------------
$tbl = '
<table cellpadding="2" cellspacing="2" >
<tr style="background-color:#666666;color:#FFFFFF;font-size:1.5em;" align = "center">
<th colspan="5" >ข้อมูลบัตรประชาชน</th>
</tr>
<tr style="background-color:#999999;color:#ffffff;font-size:1em; font-weight: bold;" align = "center">
<td>ID</td>
<td>NID</td>
<td>Name</td>
<td>surname</td>
<td>Image</td>
</tr>';
foreach ($names as $id => $result) {
// กำหนดภาพ
if (isset($images[$id])) {
// ทำตาม https://stackoverflow.com/a/48044631/128761 แนะนำ คือจับยัดลง stream.
$imageContent = file_get_contents($images[$id]);
$path = tempnam(sys_get_temp_dir(), 'prefix');
file_put_contents ($path, $imageContent);
$image = '<img src="' . $path . '" alt="">';
} else {
// ไม่มีภาพ
$image = '-';
}
$tbl .= '<tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>' . $image . '</td>
</tr>';
unset($image);
}// endforeach;
$tbl.='</table>';
// output the HTML content
$pdf->writeHTML($tbl, true, false, true, false, '');
//Close and output PDF document
$pdf->Output('ThaiIDCloud.pdf', 'I');
ผมได้เอาส่วนเชื่อมต่อ mysql ออก, เปลี่ยนจาก while เป็น foreach ทั้งหมดเพื่อทดสอบของผมเองโดยไม่ต้องไปขอข้อมูล db ของ จขกท มา. ก็ขอให้ลองไปเทียบเคียงเอาเองว่าอะไรควรจะแทนที่ด้วยอะไร ไม่น่าจะยากหรอกตรงนี้.
tcpdf ให้แน่ใจว่าโหลดจากตรงนี้ https://github.com/tecnickcom/TCPDF/releases เอารุ่นใหม่ๆเลย. จากที่ผมทดลอง ใช้ 6.2.26
ประวัติการแก้ไข 2019-02-07 13:33:11 2019-02-07 13:33:38 2019-02-07 14:02:34 2019-02-07 14:07:25 2019-02-07 14:08:45
Date :
2019-02-07 13:31:14
By :
mr.v
ไม่รู้โหลด tcpdf รุ่นไหนมาใช้อีก รุ่นเก่าๆ บางทีก็ไม่ซัพพอร์ต css บางคำสั่ง
ซึ่งส่วนใหญ่ก็ใช้ได้ แบบ mini css
ขนาด colspan rowspan บางรุ่นก็ใช้ไม่ได้อีกเหมือนกัน ก็ต้องลองเองถีงจะรู้ข้อจำกัดของมััน
การใช้คำสั่ง ของ tcpdf เองก็มีข้อดีข้อด้อย คือมัน สามารถ write ลงยังตำแหน่งที่ต้องการของ กระดาษได้เลย
แต่ข้อเสียคือ มันไม่เป็น dynamic ซึ่งผู้ใช้ต้องมีจินตภาพพอสมควร เพื่อที่จะเขียนสูตรคำนวณตำแหน่งเองได้
ที่นี้พอมาใช้ html ก็มีข้อจำกัดเรื่องการใช้คำสั่ง style sheet เพราะมันใช้ไม่ได้หมดทุกรายการ ก็ต้องเลือกคำสั่งที่ใช้งานได้
และซัพพอร์ตกับแต่ละรุ่น แบบใช้รุ่นไหนก็ให้ใช้กันแบบยาวๆ ไปเลย
ส่วนการเขียนภาพ ที่ดีที่สุด ก็คือการทำให้เป็น base64 เพราะเมื่อใช้งาน ไฟล์ pdf ถ้าเป็น ออฟไลน์ มันไม่สามารถ ลิงค์ออก internet ได้
และถีงแม้จะลิงค์ออก internet ได้ url ที่ใส่ในลิงค์ ก็ต้องใส่เต็มรูปแบบ เช่น http://yourdomain/yourpath/youfile.ext ไม่สามารถใส่ แบบ relation ได้
สิ่งสำคัญที่จขกทต้องทำ เพื่อที่จะได้ปรับการเขียนให้ได้ตามต้องการ คือการหา document ของมันมาอ่าน ข้อจำกัดของมัน
Date :
2019-02-07 14:04:22
By :
Chaidhanan
หายไปเลย ตกลงทำได้หรือไม่ได้?
Date :
2019-02-07 19:48:08
By :
mr.v
ตอนนี้ได้แล้วค่า เหลือแค่จัดรูปแบบให้สวยงาม
ขอกราบขอบพระคุณทุกคนมากๆค่ะ
Date :
2019-02-08 13:44:10
By :
yanikanaja
ได้แล้วเอาโค๊ดมาบอกคนอื่นเขาบ้างก็ดีนะครับ คนที่ไม่รู้จะได้รู้ว่าแก้ได้แบบไหนบ้าง
Date :
2019-02-08 15:26:23
By :
Chaidhanan
เออ ผมลืมดูตรงนี้ด้วย ส่วนของการล้างไฟล์ temp ใน stream. เขาบอกว่างี้.
Quote: This function's behavior changed in 4.0.3. The temporary file is also created to avoid a race condition where the file might appear in the filesystem between the time the string was generated and before the script gets around to creating the file. Note, that you need to remove the file in case you need it no more, it is not done automatically.
ไฟล์ที่สร้างโดยฟังก์ชั่น tempnam() ต้องลบด้วยตัวเอง ไม่งั้นมันจะกองพะเนินเทินทึกใน folder temp แล้วกินพื้นที่เยอะ.
ก็จะเป็นอย่างนี้. (แกะโค้ดเอาเองนะ ตัดมาแค่บางส่วนให้มันเบาๆหน้าเว็บหน่อย).
Code (PHP)
$tbl = '
<table cellpadding="2" cellspacing="2" >
<tr style="background-color:#666666;color:#FFFFFF;font-size:1.5em;" align = "center">
<th colspan="5" >ข้อมูลบัตรประชาชน</th>
</tr>
<tr style="background-color:#999999;color:#ffffff;font-size:1em; font-weight: bold;" align = "center">
<td>ID</td>
<td>NID</td>
<td>Name</td>
<td>surname</td>
<td>Image</td>
</tr>';
// เพิ่ม
$tempFiles = [];
foreach ($names as $id => $result) {
if (isset($images[$id])) {
$imageContent = file_get_contents($images[$id]);
$path = tempnam(sys_get_temp_dir(), 'prefix');
file_put_contents ($path, $imageContent);
$tempFiles[] = $path; // เพิ่ม
$image = '<img src="' . $path . '" alt="">';
} else {
$image = '-';
}
$tbl .= '<tr style="background-color:#ffffcc;color:#000000;font-size:1em;">
<td>'.$result["id"].'</td>
<td>'.$result["idnum"].'</td>
<td>'.$result["nameT"].'</td>
<td>'.$result["surnameT"].'</td>
<td>' . $image . '</td>
</tr>';
unset($image);
}// endforeach;
$tbl.='</table>';
// output the HTML content
$pdf->writeHTML($tbl, true, false, true, false, '');
//Close and output PDF document
$pdf->Output('ThaiIDCloud.pdf', 'I');
// เสร็จงานแล้วล้างไฟล์ temp.
if (is_array($tempFiles)) {
foreach ($tempFiles as $tempFile) {
unlink($tempFile);
}// endforeach;
}// endif;
ประวัติการแก้ไข 2019-02-08 21:57:48
Date :
2019-02-08 21:56:42
By :
mr.v
Load balance : Server 00