Listing 1.
#!/usr/bin/perl -w
use strict;
use diagnostics;
# available from https://www.perl.com/CPAN/
use CGI;
use Mysql;
# ----------------------------------------
# Name some global variables
my $sender_name = "";
my $sender_email = "";
my $recipient_name = "";
my $graphic_name = "";
my $postcard_text = "";
# Create an instance of CGI
my $query = new CGI;
# Send an appropriate MIME header
print $query->header("text/html");
# Get the name to match from the query string
my $id = $query->param("keywords");
# Check that the user entered a postcard ID
if ($id == 0)
{
print $query->start_html(-title =>
"No ID given!");
print "<P>Sorry, but I can retrieve ";
print "postcards only when an ID number is ";
print "provided. Please enter one, and I ";
print "will try to find a postcard ";
print "matching that ID number.</P>\n";
print "<isindex>\n";
print $query->end_html;
exit;
}
# Connect via Unix sockets to the database on
# this server
my $dbh = Mysql->connect("localhost", "test");
# Build up our SQL command
my $command = "";
$command = "select sender_name,sender_email,";
$command .= "recipient_name,graphic_name,";
$command .= "postcard_text from postcards ";
$command .= "where id_number = $id";
# Uncomment for debugging
# print "<P>SQL command: \"$command\"</P>\n";
# Send the query
my $sth = $dbh->query($command);
# Make sure that $sth returned reasonably
die "Error with command \"$command\""
unless (defined $sth);
# Report an error if no rows are returned
if ($sth->numrows == 0)
{
print $query->start_html(-title =>
"Invalid ID!");
print "<P>Sorry, but the ID number you ";
print "provided does not match any postcard";
print "in my database. Please try again, ";
print "and I will try to find a postcard ";
print "matching that ID number.</P>\n";
print "<isindex>\n";
print $query->end_html;
exit;
}
# ----------------------------------------------------
# Iterate through the returned rows
my @arr = ();
while (@arr = $sth->fetchrow)
{
# Assign our variables to the returned row
($sender_name, $sender_email, $recipient_name,
$graphic_name, $postcard_text) = @arr;
}
# ----------------------------------------------------
# Begin the HTML output
print $query->start_html(-title =>
"Postcard for $recipient_name");
print "<img src=\"/tmp/$graphic_name\"</P>\n";
print "<P><pre>$postcard_text</pre></P>\n";
print "<P>From $sender_name ($sender_email)</P>\n";
# End the HTML
print $query->end_html;
exit;