Solved

Two actions - Two submit buttons

Posted on 2007-12-05
5
202 Views
Last Modified: 2011-10-03
I have this page - http://elan.champlain.edu/~rcoughlin32001/booksonline.html - and submits the data to a database.

The first button submits the page to the database
The second button i want to be able to retrieve the password based on the account number given.

I am confused on how to make each a different action. I have them as two different names..but am not sure how to call them in Perl. In PHP I know you can do a REQUEST say and have it equal a name.

I am thinking a simple IF ELSE

IF CREATE

   CREATE ACCOUNT

ELSE RETRIEVE

  RETRIEVE PASSWORD
  SQL SELECT STATEMENT FROM DB

Any ideas?

Thanks,

Ryan


#!/usr/bin/perl

use CGI qw(:standard);

use CGI::Carp qw(fatalsToBrowser); # errors will fall to browser and be printed

use DBI;

use strict;
 

print "Content-type:text/html \n\n";
 

# username and password for the user

my $acc_num   = param('acc_num');

my $password  = param('password');
 

# login information

my $database  = "rcoughlin32001";

my $dbuser    = "rcoughlin32001";

my $dbpass    = "lacrosse";
 

# select, type, database, server

my $dsn       = "DBI:mysql:$database:localhost";
 

# connect

my $dbh       = DBI -> connect($dsn, $dbuser, $dbpass, {RaiseError => 1}) or die "Error connecting: $DBI::errstr\n";
 

	# encrypt then store in database

	# replace a-k with 0-9

	$password  =~ tr/[a-k]/[0-9]/;

	

	# store data in database

	my $query = $dbh -> prepare("INSERT INTO bookaccounts (ID, acc_num, password) VALUES (null, '$acc_num', '$password')");

	my $done  = $query -> execute();

	

	if($done){

		print "Added to database.<br />";

	}else{

		print "Didn't add to database. <a href=\"../booksonline.html\">Click</a> to go back.<br /><br />";

	}

	# for debug

	print "<b>OUTPUT</b><br /><br />";

	print "<b>Account Number:</b> " . $acc_num . "<br/>";

	print "<b>Password:</b> " . $password;

Open in new window

0
Comment
  • 3
5 Comments
 
LVL 48

Accepted Solution

by:
Tintin earned 400 total points
ID: 20416647
You could leave your form as is, but I find it easier to use the same submit name, eg:

<input type="submit" name="action" value="Create Account" /><label></label>
<input type="submit" name="action" value="Retrieve Password" />

Then in the Perl script, you do

my $action = param('action');

if ($action eq 'Create Account') {
  ...
}
elsif ($action eq 'Retrieve Password') {
..
}
0
 
LVL 1

Author Comment

by:catonthecouchproductions
ID: 20416700
Nice..thank you! Easier than i thought it would be!

I get this:

>>Can't call method "execute" on an undefined value at booksonline.cgi line 54.

Line 54:       my $sth-> execute;

Any ideas? And to decrypt..does that look right..what i have in my code?

Thanks!
#!/usr/bin/perl

use CGI qw(:standard);

use CGI::Carp qw(fatalsToBrowser); # errors will fall to browser and be printed

use DBI;

use strict;
 

print "Content-type:text/html \n\n";
 

# username and password for the user

my $acc_num   = param('acc_num');

my $password  = param('password');

my $action    = param('action');
 

# login information

my $database  = "rcoughlin32001";

my $dbuser    = "rcoughlin32001";

my $dbpass    = "lacrosse";
 

# select, type, database, server

my $dsn       = "DBI:mysql:$database:localhost";
 

# connect

my $dbh       = DBI -> connect($dsn, $dbuser, $dbpass, {RaiseError => 1}) or die "Error connecting: $DBI::errstr\n";
 

# if create account was pushed

if($action eq 'Create Account'){
 

	# encrypt then store in database

	# replace a-k with 0-9

	my $encrypt_pass  =~ tr/[a-k]/[0-9]/;

	

	# store data in database

	my $query_create = $dbh -> prepare("INSERT INTO bookaccounts (ID, acc_num, password) VALUES (null, '$acc_num', '$password')");

	my $done  = $query_create -> execute();

	

	if($done){

		print "Added to database.<br />";

	}else{

		print "Didn't add to database. <a href=\"../booksonline.html\">Click</a> to go back.<br /><br />";

	}

	# for debug

	print "<b>OUTPUT</b><br /><br />";

	print "<b>Account Number:</b> " . $acc_num . "<br/>";

	print "<b>Password:</b> " . $password;

}elsif($action eq 'Retrieve Password'){

	

	# decrypt then print

	# replace a-k with 0-9

	my $decrypt_pass  =~ tr/[0-9]/[a-k]/;

	

	# store data in database

	my $query_retrieve="SELECT password FROM bookacounts WHERE acc_num=\"$acc_num\"";

	my $sth = $dbh->prepare($query_retrieve);

	my $sth-> execute;

	

	print $sth;

}

Open in new window

0
 
LVL 28

Assisted Solution

by:FishMonger
FishMonger earned 100 total points
ID: 20416708
Change
my $sth-> execute;

To
$sth-> execute;
0
 
LVL 1

Author Comment

by:catonthecouchproductions
ID: 20416769
Thank you both!
Ryan
0
 
LVL 1

Author Closing Comment

by:catonthecouchproductions
ID: 31413030
Worked like a charm!

Thanks again,

Ryan
0

Featured Post

Top 6 Sources for Identifying Threat Actor TTPs

Understanding your enemy is essential. These six sources will help you identify the most popular threat actor tactics, techniques, and procedures (TTPs).

Join & Write a Comment

I've just discovered very important differences between Windows an Unix formats in Perl,at least 5.xx.. MOST IMPORTANT: Use Unix file format while saving Your script. otherwise it will have ^M s or smth likely weird in the EOL, Then DO NOT use m…
Many time we need to work with multiple files all together. If its windows system then we can use some GUI based editor to accomplish our task. But what if you are on putty or have only CLI(Command Line Interface) as an option to  edit your files. I…
Explain concepts important to validation of email addresses with regular expressions. Applies to most languages/tools that uses regular expressions. Consider email address RFCs: Look at HTML5 form input element (with type=email) regex pattern: T…
This tutorial demonstrates a quick way of adding group price to multiple Magento products.

705 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

Need Help in Real-Time?

Connect with top rated Experts

19 Experts available now in Live!

Get 1:1 Help Now