ID:               34253
 Comment by:       najath at onlnet dot com
 Reported By:      inny at core dot fetchnet dot org
 Status:           Assigned
 Bug Type:         COM related
 Operating System: Windows 2000
 PHP Version:      5.1.0RC1
 Assigned To:      wez
 New Comment:

hi i am using 5.1 PHP and MYSQL

my project is to store images and retrive binary values and convert to
an image format again 

i have inserted the binary values to the feild and i have retrived also
but always i am getting the binarys not the image. plesae help me 


print ("<img src=". $row['bi']."/>");


Previous Comments:
------------------------------------------------------------------------

[2005-08-26 15:01:49] [EMAIL PROTECTED]

Assigned to maintainer.


------------------------------------------------------------------------

[2005-08-26 11:56:56] inny at core dot fetchnet dot org

"Amusingly" enough, the array_reduce method didn't work for PHP5. I
guess that makes sense though.

-- Oh don't worry, I'm having lots of fun (on my own) in my own little
thread already.

------------------------------------------------------------------------

[2005-08-26 11:16:57] inny at core dot fetchnet dot org

I was adding support for PHP4 to the script, which made me wonder: if
binary arrays are meant to be received like this, what would be the
fastest way to reformat them?

        foreach ($content As $obj) {
        // or foreach($content->value As $obj) in PHP4
          $image .= chr($obj);
        }
        echo($image);

or maybe something like

        function rchr($v, $w) {
          $v .= chr($w);
          return($v);
        }
        $image = array_reduce($content, rchr);
        // or $image = array_reduce($content->value, rchr); in PHP4

or something else?

Thanks.

------------------------------------------------------------------------

[2005-08-25 18:37:36] inny at core dot fetchnet dot org

FYI, source of a now-operational version here:

http://demis.inny.org/temp/wms_working.php.txt

Non-operational script as .phps file:

http://demis.inny.org/temp/wms.phps

------------------------------------------------------------------------

[2005-08-25 18:31:46] inny at core dot fetchnet dot org

Description:
------------
I was translating the following script:
http://demis.inny.org/temp/wms.asp.txt
http://demis.inny.org/temp/wms.php.txt is a non-functional translation
I had at that time.

If $QueryString ($_SERVER['QUERY_STRING']) contained the proper
variables/values, the WMSServer would return a
byte-stream/array/whatever (I'm no genius at COM and such) containing a
map-image.

http://demis.inny.org/temp/wms.php.txt would return, instead of the
image, 8 question marks (????????). I solved this by changing
echo($content); into the following:

if (substr($contenttype, 0, 5) == 'image') {
  $image = null;
  foreach ($content As $obj) { // $obj will contain 1 byte each time,
echo'ing it would print a decimal which in turn represents an ASCII
value. hence chr();
    $image .= chr($obj);
  }
  echo($image);
} else {
        echo($content);
}

But this doesn't seem too resource-efficient to me (a run of foreach
for every byte), and I doubt it's an intended work-around (the ?'s
really got me puzzled, I'd have expected an error message).


Anyway, seeing as I needed to use chr(); with foreach, this seems
related to a fixed bug #15782: http://bugs.php.net/bug.php?id=15782

Maybe you were aware of all of this.. Maybe not. Cheers.

Reproduce code:
---------------
$WMSService = new COM("DemisWMSConnect.Service");
$MapServer = $WMSService->WMS($wms);

if (!is_object($MapServer)) {
        dosomestuffand();
        die();
} else {
        $content     = new VARIANT(null);
        $contenttype = new VARIANT(null);
        $return = $MapServer->WMSRequest($QueryString, $content,
$contenttype);
        header('Content-type: '.$contenttype);
        echo($content);
}



------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=34253&edit=1

Reply via email to