Solved

Need to export all jpeg files (blob entries) to filesystem

Posted on 2008-06-16
5
2,281 Views
Last Modified: 2013-12-13
We have an old Linux box setup years ago as a PHP/MySQL based webserver.  We're upgrading it to a new server, and need to get all the images (jpeg type) that are stored in the sql database out to the filesystem.  I found a PHP script to do just that, but I'm having problems.  I think my problems are that this server is running PHP 4.3.2.  We have no expertise in Linux, or PHP, so we're trying to extract this info without putting effort into upgrading the system first.  I know this has got to be a simple thing to do.  Any ideas?  Oh, the way it's to name the file, is to take and combine the info in 2 of the fields in the table, and append .jpg on the end of it.

I have attached my code.  What's happing when I run it, is that it appears to be bypassing the PHP engine because it simply shows me the PHP code in my browser.  I've tested PHP with the phpinfo() function and that works fine.

Thanks for your help.
< ?php
$location="/var/www/website.com/html/imagearchive/";
 
$db = mysql_pconnect("localhost");
mysql_select_db("database",$db);
 
$sql="select person.name, media.id, media.data from media LEFT JOIN person ON (person.id=media.l_table_name_id)";
 
$rs = mysql_query($sql,$db);
 
echo "<h2>EXPORTING INTO $location</h2>";
$counter=0;
while ($row=mysql_fetch_object($rs)) {
$filename=$location.$row->person.name"."media.id..jpg;
$file=fopen($filename,w');
if (fwrite($file,$row->image)) {
echo $filename.<br />;
$counter++;
}
}
 
echo <h2>$counter images exported</h2>;
? >

Open in new window

0
Comment
Question by:ResortCompanies
5 Comments
 

Expert Comment

by:qaelan
ID: 21798939
You might try removing the spaces between

< ?php

and

? > 

At the start and end of the file. They should be <?php and ?>, respectively
0
 
LVL 18

Expert Comment

by:Matthew Kelly
ID: 21799017
Try this code. The php being output to the screen is caused by the space between the ? and the > sign at the start and end.

There are also a few php syntax errors, which I corrected below.

Let me know if I did not code it right.


<?php
$location="/var/www/website.com/html/imagearchive/";
 
$db = mysql_pconnect("localhost");
mysql_select_db("database",$db);
 
$sql="select person.name, media.id, media.data from media LEFT JOIN person ON (person.id=media.l_table_name_id)";
$rs = mysql_query($sql,$db);
 
echo "<h2>EXPORTING INTO ".$location."</h2>";
 
if ( $rs && mysql_num_rows($rs) > 0 )
{
	$counter=0;
	for ( $i=0; $i < mysql_num_rows($rs); $i++ )
	{
		$name = mysql_result($result,$i,0);
		$id = mysql_result($result,$i,1);
		$data = mysql_result($result,$i,2);
		$filename = $location.$name.$id.".jpg";
		$file=fopen($filename,'w');
		if (fwrite($file,$data)) 
		{
			echo $filename."<br />";
			$counter++;
		}
	}
}
else
{
echo "No files found";
}
 
echo "<h2>".$counter." images exported</h2>";
?>

Open in new window

0
 
LVL 29

Accepted Solution

by:
fibo earned 500 total points
ID: 21800367
Some typos and errors with ' and ".
Code is easier to grasp and debug when indented.

If doing lots of development, you shoud consider using commercial PHP IDEs like Zend or NuCoder: they would help you spotting at once these typos.
They offer trial versions that you can use for free for 2 or 4 weeks: this will help you to determine if the time you save is worth the money. They both have a "personal" version at $100-120.

<?php
$location="/var/www/website.com/html/imagearchive/";
 
$db = mysql_pconnect("localhost");
mysql_select_db("database",$db);
 
$sql="select person.name as my_name, media.id as my_id, media.data as my_data 
from media LEFT JOIN person ON (person.id=media.l_table_name_id)";
 
$rs = mysql_query($sql,$db);
 
echo "<h2>EXPORTING INTO $location</h2>";
$counter=0;
while ($row=mysql_fetch_object($rs)) {
  $filename=$location.$row->my_name . '.' . $row->my_id . '.jpg';
  echo "$filename :";
  $file=fopen($filename,'w');
  if (fwrite($file,$row->my_data)) {
    echo "OK<br />";
    $counter++;
  } else echo 'fail **<br>';
}
 
echo "<h2>$counter images exported</h2>";
?>

Open in new window

0
 

Author Closing Comment

by:ResortCompanies
ID: 31467823
Thanks, worked like a charm.
0
 
LVL 29

Expert Comment

by:fibo
ID: 21805535
Glad it worked, thx for the points
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Download tables into separate sheets 3 28
Slow MySQL (InnoDB) Query with Inner Join & GroupBy 7 46
two ways encryption with php 3 28
Cookie not unsetting 7 20
I imagine that there are some, like me, who require a way of getting currency exchange rates for implementation in web project from time to time, so I thought I would share a solution that I have developed for this purpose. It turns out that Yaho…
Does the idea of dealing with bits scare or confuse you? Does it seem like a waste of time in an age where we all have terabytes of storage? If so, you're missing out on one of the core tools in every professional programmer's toolbox. Learn how to …
Learn how to match and substitute tagged data using PHP regular expressions. Demonstrated on Windows 7, but also applies to other operating systems. Demonstrated technique applies to PHP (all versions) and Firefox, but very similar techniques will w…
The viewer will learn how to count occurrences of each item in an array.

809 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question