如何从mysql中选择和回显图像

时间:2013-08-26 20:08:27

标签: php javascript mysql

我正在尝试从mysql获取信息,包括blob图像,我将用php回复,并在php中有一个onclick事件,将其重定向到另一个页面。 onlick事件将包含一个mysql结果,它将携带它,如下面的代码所示。

我的主要问题是代码的语法,或者是否有另一种方法可以一起完成。请记住脚本运行时的输出与谷歌图像,bing图像等类似。谢谢。

<?php
$con=mysqli_connect("localhost","root","*******","media");
// Check connection
if (mysqli_connect_errno())
{
 echo "Failed to connect to MySQL: " . mysqli_connect_error();
}

$result = mysqli_query($con,"SELECT * FROM movies ORDER BY  `movies`.`title` ASC");

echo "<table border='3' style='margin: auto; text-align: left;background: white;      padding: 3em;'>
<tr>
<th><b>Movie Title</b></th>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
<th><b>Language</b></th>
</tr>";

while($row = mysqli_fetch_array($result))
 {
  echo "<tr>";
  echo "<td style='padding-right: 2em;'><img src="data:image/jpeg;base64,' .  base64_encode( $row['image'] ) . '"  width="160px" height="200px";" onclick="window.location='lookup.php?pattern=" . $row['title'] . "';>";
</td>
 echo "</tr>";
 }
echo "</table>";

mysqli_close($con);
?>  

2 个答案:

答案 0 :(得分:0)

未经测试,但这里有一种方法可以清理代码移动样式和javascript(并使用一些jquery)到头部:

<?php
    $con=mysqli_connect("localhost","root","*******","media") or die("Failed to connect to MySQL: " . mysqli_connect_error());
    $result = mysqli_query($con,"SELECT * FROM movies ORDER BY  `movies`.`title` ASC");
?>
<html>
    <head>
        <script src="//ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>
        <script>
            $(document).ready(function() {
                $('img').each(function() {
                    var img = $(this);
                    img.click(function() {
                        window.location="lookup.php?pattern=" + img.attr('title');
                    });
                });
            });
        </script>
        <style>
            table {
                margin: auto;
                text-align: left;
                background: white;
                padding: 3em;
                border: 2px solid #000000;
            }
            table tr td {
                padding-right: 2em;
            }
            table tr td img {
                width: 160px;
                height: 200px;
            }
        </style>
    </head>
    <body>
        <table>
            <tr>
                <th>Movie Title</th>
                <th>Language</th>
            </tr>
            <?php
                while($row = mysqli_fetch_array($result)) {
                    echo "
                        <tr>
                            <td>
                                <img src=\"data:image/jpeg;base64," .  base64_encode( $row['image'] ) . "\" title=\"" . $row['title'] . "\">
                            </td>
                        </tr>
                    ";
                }
            ?>
        </table>
    </body>
</html>
<?php mysqli_close($con); ?>

或者,如果您不想使用javascript,您可以始终将图像包裹在锚标记周围:

<td>
  <a href='lookup.php?pattern={$row['title']}'>
    <img src=\"data:image/jpeg;base64," .  base64_encode( $row['image'] ) . "\">
  </a>
</td>

答案 1 :(得分:0)

您可以进一步分离PHP和HTML代码:

<?php
    $con=mysqli_connect("localhost","root","*******","media");
    // Check connection
    if (mysqli_connect_errno()) {
        echo "Failed to connect to MySQL: " . mysqli_connect_error();
        die();
    }
    $result = mysqli_query($con,"SELECT * FROM movies ORDER BY  `movies`.`title` ASC");
?>
<table border='3' style='margin: auto; text-align: left;background: white;      padding: 3em;'>
    <tr>
        <th><b>Movie Title</b></th>
        <th><b>Language</b></th>
    </tr>
<?php
    while($row = mysqli_fetch_array($result)) {
        $img = 'data:image/jpeg;base64,'
             . base64_encode( $row['image'] );
?>
<tr>
  <td style='padding-right: 2em;'>
      <img src="<?php echo $img; ?>"
          style="width: 160px; height: 200px;"
          onclick="window.location='lookup.php?pattern=<?php echo $row['title']?>;'"
      />
  </td>
</tr>
<?php } ?>
</table>

<?php
    mysqli_close($con);
?>

你也可以使用某种模板引擎来做到这一点,但结果几乎是一样的 - 我没有看到写作的重点,比如说,

     <strong>{{ title }}</strong>

而不是

     <strong><?php echo $title; ?></strong>