Presentation is loading. Please wait.

Presentation is loading. Please wait.

CGI programming Using Apache. Concepts Browser prepares parameter list List is attached to name of program to run on server "submit" button sends string.

Similar presentations


Presentation on theme: "CGI programming Using Apache. Concepts Browser prepares parameter list List is attached to name of program to run on server "submit" button sends string."— Presentation transcript:

1 CGI programming Using Apache

2 Concepts Browser prepares parameter list List is attached to name of program to run on server "submit" button sends string to server as name/value pairs Server locates program in CGI directory Server loads program Server passes string to program Program processes parameters and acts as needed Program creates strings and outputs to server One line of HTML code per output statement (cout, printf, etc) ALL stream output goes to the Server Server sends strings to browser Browser interprets the HTML code & displays the "page"

3 CGI output (C++ example) #include cout << "Content-Type: text/html\n\n" << endl; cout " << endl; // HTML 5 cout " << endl; …. Your HTML & text go here … cout " << endl; 1 st line identifies output media type to browser 2 nd line identifies document type version 3 rd line is actual start of the page

4 Content-type problems Inability of data source to identify content Wrong file extension Bad file extension Extension collisions Ambiguous container formats Ambiguous magic numbers Inability of receiver to trust sender's media type Programmers try to guess content type by examination

5 Using styles Output is a stream representing a single "file" HTML files do NOT have to have one tag per line Output can be individual lines or several long lines: cout text item1 "<<endl; Styles can be embedded or inline Generate style tags just like any other HTML cout.red {font:red} " << endl; cout << ".bigtext {text-size:150%} " << endl; " << endl;

6 Using JavaScript JS can be inserted: as functions in As inline code inside in body of doc CGI generated pages "act like" real pages

7 Getting to your server Connecting to the TJW machine Go to SSL>BINGHAMTON>EDU and download the MTN3270 (Mocha) program Edit the properties of mtn3270 to be sure you are going to bingTJW, not bingTZ1. Login to the TJW mainframe using MTN3270 Your 3270 userid & password are on my Grade Tracker Follow the prompts then type: #CP DISC" and your session will disconnect. Close the window. Login to TJWnnn.cc.Binghamton.edu using Putty or SSH The userid & password will ONLY be given to you in class. You can now use the editor named “nano” to edit files. To work in full GUI mode, type: vncserver It will prompt you for a NEW password. Make one up. This will be for your VNC client to connect (for a 3 rd time) to your system. I recommend the freeware program called “tightvnc”. You can now close Putty. Download & install your VNC client, then use it to login in GUI mode

8 Navigating a website Do I have to install Apache on my PC? No. The Apache server is only on the server (TJW) and is already installed. Here is the data flow: 1.User has your form “somewhere”. It could be a simple file on their hard drive or in the HTML folder of your webserver machine (TJW in this case). 2.User completes the form and clicks “submit” 3.The “action=” attribute of the FORM tag tells their browser to gather the input fields and send them to wherever the “action” attribute says to send them 4.The TJW Apache server sees the incoming request for your CGI program. The program MUST be in var/www/cgi-bin directory (after you compile it on TJW and move the executable-output (a.out) there from your home directory.) You SHOULD rename a.out to something more meaningful and that is the name to use in your “action=” attribute. 5.The Apache server loads the program and passes your input fields as command-line arguments, just like any program started form a command-line. Your program gets them via: void main(int argc, char*argv[]) {} 6.Your program gets the data, processes it and outputs a webpage as we discussed in class. The output is sent by the Apache server to the user’s browser which then displays the page you built with the results.

9 Activating your CGI program Generate an HTML form (using cout or printf): … {your JS function def's and html and go here} document.myform.submit(); // this submits the form to the browser Where I have "chkflds" you could put the name of a function to validate the fields The function would have to be inside and tags RECOMMENDATION: put the form's elements inside a table.. Input/button tags here…

10 Setting up your Apache server Open terminal window Type: nano /etc/httpd/conf/httpd.conf (or use your favorite editor instead of nano) Locate "ServerAdmin" and replace the email address with yours Locate "ServerName" and replace the default with your TJWnnn account (tjwnnn.cc.binghamton.edu) Save the file using the same name it had In the terminal window type the following command: apachectl start Close your session

11 Testing your web server Create a simple web page Save it in /var/www/html with the name: index.html Open a browser on your own PC (NOT on the TJW machine) Enter the address of your tjw account e.g.; tjw241.cc.binghamton.edu (that's mine!!) You should now see your test page


Download ppt "CGI programming Using Apache. Concepts Browser prepares parameter list List is attached to name of program to run on server "submit" button sends string."

Similar presentations


Ads by Google