TechTip: Automatically Refresh Web Pages PDF Print E-mail
Written by Jan Jorgensen   
Thursday, 18 January 2007

With RPG CGI and JavaScript, you can automatically update Web page information.

Most of you have been in airports or train stations and seen the big screens that inform you that a plane or train is boarding, late, or cancelled. This information has to come from somewhere, and it has to be controlled by some kind of timer. This tip will show you a technique to do that sort of thing.

I've seen my share of dull examples showing item masters or customer sales. But everybody has a favorite song, so I'll use "top hits" for my example. You can vote and even learn something useful too!

To give you an overview, here is what you get:

  1. A "top hits" program, which also lets you cast a vote
  2. A setup program from which you can dynamically change the look of the hit list
  3. A way to prompt for colors
  4. Some JavaScript knowledge you might not be aware of

So the tone is set. Let's roll.

How to Refresh a Web Page

There are two ways (that I am aware of) you can refresh a Web page.
You can use a meta tag, which is placed in the section of the HTML document, or you can use JavaScript.

The meta tag looks like this:



This tells the browser that it should reload the page every 10 seconds by calling program form010.

(Note: In IE 7.0, you can disable the meta refresh, so if you have done that and also disabled JavaScript, this won't work.)

I have always used the meta tag method, but some clever people do things a better way. On GrizzlyWeb.com, I found a very good and useful JavaScript Refresh example that also taught me something about JavaScript that I never knew.

When you use JavaScript in an HTML document, you can write


Press F5 to re-display Pop-up

You can test it here.

To refresh the page, use one of three methods:

  • window.location.href (for JavaScript below 1.1)
  • window.location.replace (for JavaScript 1.1)
  • window.location.reload (for JavaScript 1.2)

Basically, they do the same thing; the difference is in the cache and history controlling. If you want to dig into it, check out the JavaScript Refresh example. Otherwise, just accept what your browser is doing.

Now, you need to control the refreshing, so let's look at how to get some data to refresh. I have created two sample files: WWWHITLIST holds the information about the songs in the "top hits" list, and WWWSETUP holds information about the way the list will look, the number of entries to show, refresh time, and more.

The RPG CGI program FORM010 is pretty straightforward. The flow is like this:

  1. Read input from HTML form/Query string (if any).
  2. Read setup data (I have only one record in WWWSETUP). If no data is found in setup file, a default record is created.
  3. Read HTML skeleton file from the IFS (thanks to Scott Klement for the API wrapper).
  4. Create HTML reply/read hit list data.
  5. Wait for next refresh.

The default hit list looks like this:

http://www.mcpressonline.com/articles/images/2002/autorefreshV4--01190700.jpg

Figure 1: RPG CGI program FORM010 creates the default hit list with a refresh time of 10 seconds. (Click images to enlarge.)

Cast a Vote

For viewers to cast a vote, RPG CGI program FORM010 must be called with a parameter called "votemode" and must be set to Y (in uppercase). When this is done, the refresh is suspended, and the list looks like this:

http://www.mcpressonline.com/articles/images/2002/autorefreshV4--01190701.jpg
Figure 2: The program is ready to accept votes.

Every time someone votes, the list will refresh. If you open another browser and load the list in refresh mode, you will of course see it change every time the refresh time is reached.

Set Up the List

I have created RPG CGI program FORM011 to change the look and feel of the list. When loaded, the program looks like this:

http://www.mcpressonline.com/articles/images/2002/autorefreshV4--01190702.jpg
Figure 3: RPG CGI program FORM011 changes the look and feel of the list.

You can clearly see what you can change, and the program works the same way as any other update program except that the input is coming from an HTML form.

I found the "color prompter" at >free-color-picker.com. In my opinion, it's very clever and also easy to implement. So, for example, if you want to change the background header color, click the button. You'll see the following:

http://www.mcpressonline.com/articles/images/2002/autorefreshV4--01190703.jpg
Figure 4: Prompt for a color.

When you click on a color, the color value will be transferred back to the HTML form and the pop-up will close.

Downloading and Installing

  1. Create a directory in your root directory called /root/mcpressonline by entering the following command: md '/root/mcpressonline/'
  2. Create a dir called autorefresh inside mcpressonline. Enter the following: md '/root/mcpressonline/autorefresh'
    Note: If you place it somewhere else, you must change the following files to reflect your placement: javascript file 302pop.js and variable IFSpath in FORM010 and FORM010.
  3. Download refresh.zip. Unzip and upload everything to '/root/mcpressonline/autorefresh'. It should look like this:

    http://www.mcpressonline.com/articles/images/2002/autorefreshV4--01190704.jpg
  4. Compile >WWWHITLIST, WWWHITLISL, and WWWSETUP or restore save file wwwhitlist.savf to your i5 (saved with TGTRLS(V5R1M0)).
  5. Save copy book for BUFIO_H to your i5.
  6. Download and save the source to FORM010 and FORM011 on your i5.

Before compiling...

  • Change the "your-data-lib" in the RPG sources to where you placed the data files.
  • Change "root-dir" in constant IFSpath to your actual root dir.
  • In FORM010, change "your-server" to your Web server name in variable reloadURL.

When you have installed everything and compiled the RPG programs (compile instructions can be found in the header description), you can test the list.

Load the list: http://your-server-name/cgi-bin/form010

Cast a vote: http://your-server-name/cgi-bin/form010?votemode=Y

Set up the list: http://your-server-name/cgi-bin/form011

When you want to add new songs to the list, enter data into WWWHITLIST using DFU or your favorite database editor.

Happy New Year

Once again, I hope this tip has proved how a little JavaScript, some good old RPG, and a few creative thoughts can help you build applications that serve data in ways you might not have thought of before.

Jan Jorgensen is a programmer at Electrolux Laundry Systems Denmark. He works with RPG, HTML, JavaScript, and Perl. You can reach him at This e-mail address is being protected from spam bots, you need JavaScript enabled to view it .


Last Updated ( Thursday, 18 January 2007 )
 
Discuss (12 posts)
Ralph Daugherty
TechTip: Automatically Refresh Web Pages
Feb 12 2007 23:02:00
I took a look at your screen shot, Araman, and like you say, it was a nifty piece of work from Jan. Nice looking web page, and a lot of functionality in that code. I've got to hustle to keep up with you guys. :) <p> rd
#121177
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 12 2007 22:20:00
Hi Mr Daugherty... <p>I find excitement and sense of achievement by trying all these stuff. <BR>
It sparks many ideas and open all the possibilities for system development.. I would try to find time to try all the stuff that come to my interest. I would stayed back after work to do it even if its not for overtime just for the fun of trying. In fact, that what I've been doing for the past few years. Who knows, a little extra time spend can save a lot in the future. Thanks to all the guru's (including you) who keeps the juices flowing. <p>Araman. <p>Sime Solution Centre Sdn Bhd
#121176
Ralph Daugherty
TechTip: Automatically Refresh Web Pages
Feb 11 2007 17:34:00
And there's so much to learn. But you're ahead of me in trying all this stuff out. <p> rd
#121175
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 11 2007 15:43:00
Hi Araman, <p>Glad you got the cent/# to work <p>I do not know how you installed the program - but if you did NOT install it like <p>/mcpressonline/autorefresh <p>you must go into the /mcpressonline/autorefresh/javascript dir and locate javascript 302pop.js and find the line which refer to fcp302.html - in front of that is the path to the file and that should match how you installed the tool. <p>Please let me know if that is the case? <p>Best regards <BR>
- Jan
#121174
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 11 2007 12:34:00
I guess I'm a slow learner.. <BR>
I'll try to refer back on your replies. <p>Thanks for reminding me.. <BR>
You've been a real help.. <BR>
Araman
#121173
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 11 2007 09:49:00
Err.. you're right.. The data is in cent.. <BR>
I've changed it using DFU and it shows #. <BR>
Another problem though.. <BR>
The fcp302.html doesn't popped up. <BR>
I got error on my status bar, it just said object expected. <BR>
Couldn't find any message in the Sun Java Console. <BR>
I'm still working on it.. <p>Thanks.. <BR>
Araman
#121172
Ralph Daugherty
TechTip: Automatically Refresh Web Pages
Feb 10 2007 14:30:00
Hi Araman, I thought I showed you how to check the various CCSID values and the hex values in your file? :) <p> Plus the entire source code is provided, if you compile them yourself whatever CCSID values you have going there will be applied. If there is a problem it will be with the web server translation as we determined before in the STRCGISQL episode, I believe. <p> Hope you don't have to do the same code modification again. <p> rd
#121171
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 10 2007 12:33:00
Could you please try loading the file in DFU or something like it and manually change the cent sign to # and let me know the outcome? <p>Sorry about all the trouble... <p>- Jan
#121170
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Feb 09 2007 11:29:00
Hi Mr Jan <p>Are you saying to do CHGPF FILE(CGIDATA/WWWSETUP) CCSID(*HEX)? <BR>
Err.. done that. Doesn't work.. <p>Thanks.. <p>Rgds <BR>
Araman.
#121169
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Jan 19 2007 12:30:00
Hi Araman, <p>Just a quick guess - try to change the CCSID on the WWWSETUP file to *HEX (65535) - if it does not work let me know and I'll dig more into it... <p>Best regards <BR>
- Jan
#121168
Guest.Visitor
TechTip: Automatically Refresh Web Pages
Jan 19 2007 09:33:00
Hi Mr Jan <p>I'm having problem with the setup page. <BR>
It shows hash (#) value to be cent (¢) value. <BR>
And the 'Error on page' shows "Invalid property value". <BR>
Anything I must change on my PC side? <p>The refresh page works great. <p>Thanks..
#121167
MC Press Web Site Staff
TechTip: Automatically Refresh Web Pages
Feb 12 2007 23:02:00
This is a discussion about <B>TechTip: Automatically Refresh Web Pages</b>.<p align='center'><a href=http://www.mcpressonline.com/mc?1@232.1KNKfHX1eQT.17@.6b4948be>Click here for the article</a>.</p>
#121166


Discuss...
User Rating: / 0
PoorBest 
Related Articles
< Prev   Next >

   MC-STORE.COM