#!/usr/bin/perl -w use strict; use CGI qw/header cookie start_html end_html url param/; use Digest::MD5 qw(md5_hex); my %login = ( test => 'test' ); # this is just for demo $login{$_} = md5_hex($login{$_}) foreach (keys %login); sub checkSessionID { my $check = shift; my ($user,$pass) = split /:/,$check,2; return $login{$user} eq $pass ? 1:0; } sub checkUserPass { my $user = shift; my $pass = md5_hex(+shift); return $login{$user} eq $pass ? 1:0; } sub makeCookieValue { my $user = shift; my $pass = md5_hex(+shift); return "$user:$pass"; } my %options; my $cookie; # yes, dirty and disgusting...but...oh well if (param('clearCookie')) { $options{"-cookie"} = cookie(-name => 'sessionID', -value => 'bye', -expires => '-6M' # just in case ); } elsif (cookie('sessionID') && checkSessionID(cookie('sessionID'))) { $cookie = cookie(-name => 'sessionID', -value => cookie('sessionID'), -expires => '+1h' ); } elsif (param('username') && param('password') && checkUserPass(param('username'),param('password'))) { $cookie = cookie(-name => 'sessionID', -value => makeCookieValue(param('username'),param('password')), -expires => '+1h' ); } $options{"-cookie"} = $cookie if $cookie; # if you wish, you can put more header options in %options # if you wish to put more cookies, do: # $options{'-cookie'} = [ $options{'-cookie'} ]; # push @$options{'-cookie'}, $_ foreach (@more_cookies); print header(%options),start_html; # $cookie acts as our switch if ($cookie) { print "Logged in and working! Cookie: ",cookie('sessionID') ? cookie('sessionID'):"You just logged in!"; print "
"; } else { print "
Login
Pass
"; } print end_html;