Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations IamaSherpa on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Form using CGI to process writing to a .txt doesn't work

Status
Not open for further replies.

Jofunu6

Technical User
Apr 29, 2003
7
AU
I am trying to find a CGI script that can write to a .txt or even better .xls file. I have tried it on one site yet it doesn't work, please help [sad][sadeyes]
 
Here is a program placed on your server that can be called by multiple forms at the same time with locking. I show it in my Perl coding class as an example of how to capture information from visitors that fill out a form. It has not gone through any exaustive testing but can give you some pointers. It is not fancy, is well documented and simple. It writes each form field as a serarate text record with "Field_name = Field_value".

#!/usr/bin/perl

#****************************************************************************
# THIS PROGRAM READS STANDARD INPUT AND WRITES .HTM CODE BACK TO THE CLIENT *
# USING STANDARD OUTPUT TO BE DISPLAYED BY THE BROWSER. *
# IT ALSO WRITES A 'FORM's FIELD-NAMES & VALUES TO A DATA FILE. *
# THE PROGRAM IS SAVED AS "CIM355_WRITE_FORM_DATA_TO_FILE.PL" *
#****************************************************************************

#****************************************************************************
# THE FOLLOWING TWO STATEMENTS INSTRUCT THE PERL INTERPRETER TO LINK MODULES*
# FROM THE FOLLOWING TWO SUBROUTINE LIBRARIES *
#****************************************************************************
use CGI;
use CGI ':standard';
use CGI::Carp qw(fatalsToBrowser); #RETURN ERRROR CODES TO THE BROWSER

#****************************************************************************
# THE FOLLOWING LINE IDENTIFIES THE DESIRED FILE NAME FOR THE OUTPUT FILE. *
#****************************************************************************
$OUTFILE="CIM355_WRITE_FORM_DATA_TO_FILE.TXT";

#****************************************************************************
# THE FOLLOWING STATEMENT MUST BE SENT WITH THE DOUBLE LINE FEED TO *
# INFORM THE BROWSER THAT THE RETURNING DATA IS IN THE FORM OF A *
# "HTML WEB PAGE - IN TEXT FORMAT". *
#****************************************************************************
print "Content-type: text/html\n\n";

#****************************************************************************
# THE OTHER TWO LINES ARE TO DEFINE THE STANDARD HEADER & BODY OF A WEB PAGE*
#****************************************************************************
print &quot;<HTML>\n<HEAD>\n<TITLE>FORM DATA HAS BEEN PROCESSED.</TITLE>\n</HEAD>\n&quot;;
print &quot;<BODY><PRE><BR>\n&quot;;

#****************************************************************************
# NOW Lets open a LOCK file to protect against concurrent user update. *
#****************************************************************************
flock(LOCKFILE, &quot;FILELOCK.TXT&quot;);

#****************************************************************************
# NOW Lets open an OUTPUT or APPEND to a disk text file. *
#****************************************************************************
$append = &quot;yes&quot;;
if (open(FORM_REC_OUT, &quot;>>$OUTFILE&quot;))
{
print &quot;APPENDED OUTPUT FILE ON SERVER WAS OPENED\n\n\n&quot;;
}
else
{
print &quot;Cannot open $OUTFILE! FOR APPEND,\n&quot;;
print &quot;Will try to OPEN for OUTPUT.\n\n&quot;;
$append = &quot;no&quot;;
}
#----------------------------------------------------------------------------
if ($append eq &quot;no&quot;)
{
if (open(FORM_REC_OUT, &quot;>$OUTFILE&quot;))
{
print &quot;OUTPUT FILE WAS OPENED AS A NEW FILE ON THE SERVER.\n\n\n&quot;;
}
else
{
print &quot;Cannot open $OUTFILE FILE IN ANY FORMAT!\n\n&quot;;
exit 99;
}
}
#****************************************************************************
# SEND AN ACKNOWLEDGEMENT BACK TO THE CLIENT IN THE FORM OF A WEB PAGE. *
#****************************************************************************
print &quot;<CENTER><h2>&quot;;
print &quot;YOUR FORM's DATA HAS BEEN WRITTEN TO<BR>$OUTFILE<BR>ON THE SERVER.\n&quot;;
print &quot;-----------------------------------------------------------\n&quot;;
print &quot;</CENTER></h2><br>&quot;;

#****************************************************************************
# LOOP THROUGH THE STANDARD INPUT(PIPED) STREAM AND WRITE EACH INPUT FIELD *
# IN THE FORM TO A SERARATE LINE IN THE OUTPUT FILE WITH IT's NAME. *
#****************************************************************************
#print &quot;***&quot;,scalar(localtime),&quot;***\n&quot;;
($sec, $min, $hour, $mday, $mon, $year_off, $wday,$yday,$isdst)=localtime;
print FORM_REC_OUT ($mon+1,&quot;/&quot;,$mday,&quot;/&quot;,$year_off+1900,&quot; TIME &quot;,$hour,&quot;:&quot;,$min,&quot;:&quot;,$sec,&quot;\n&quot;);
while(defined($a = <STDIN>))
{
$a =~ tr/&/\n/;
$L = length($a);
print FORM_REC_OUT '=>',$L,'<=>',$a,'<=',&quot;\n&quot;; # Debug lines
$e = 0;
for ($i = 0; $i < $L; $i++)
{
if (substr($a,$i,1) eq '=')
{
$e = $i + 1;
}
}
print FORM_REC_OUT '=>',$e,'<=',&quot;\n&quot;; # Debug lines
# $a =~ tr/&/\n/;
print FORM_REC_OUT $a,&quot;\n&quot;;
}

#****************************************************************************
# COMPLETE THE ACKNOWLEDGEMENT WEB PAGE BACK TO THE CLIENT SYSTEM. *
#****************************************************************************
print FORM_REC_OUT &quot;-------------------------------\n&quot;;
print &quot;<BR>\n&quot;;
print &quot;FORM DATA WAS WRITTEN TO OUTPUT FILE.\n&quot;;
print &quot;</PRE></BODY></HTML>\n&quot;;

#****************************************************************************
# CLOSE THE DATA FILE AND THE LOCKING FILE. *
#****************************************************************************
close FORM_REC_OUT;
close LOCKFILE;
exit 0;
#****************************************************************************

Good luck.
 
Prof,

Your flock statements might need a little work, unless you've declared LOCKFILE as a constant

Cheers
Paul
 
Sorry, as a one finger data entry person I often leave out small details. I have a 1 byte text file I created that I never read/write to. I just use it as a file to lock against to serialize the operations against the text file I append to.

I also have another program I can run at any time and it locks the byte file then reads ->writes the current data to a work from file then resets the append file for more accumulations. I then download the collected data to my local client system for Cobol processing.

All in all, there are a group of files that do the whole job. I was just trying to show the basic code of txt file writing and include the concern about concurrent clients going against the server at the same time, not the whole solution.

Like I said, no exhaustive testing. Our simple test was, we got a class of users(6-7) to each bring up the form page and fill out a set of values then press the enter key at the same time. We did not have any interspersed form data.

Oh well, so much for the one finger programmer.

Prof Sparkie.
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top