Welcome!

You will be redirected in 30 seconds or close now.

ColdFusion Authors: Yakov Fain, Jeremy Geelan, Maureen O'Gara, Nancy Y. Nee, Tad Anderson

Related Topics: ColdFusion

ColdFusion: Article

Banner Rotation & Tracking

Banner Rotation & Tracking

As the owner and operator of a large entertainment site (nyrock.com), I'm often faced with this problem - my ad broker is unable to sell advertising for a small but steady number of pages.

I considered using these pages to arrange banner swaps with other sites, but without a quantitative way to monitor the cross promotion, I couldn't expect to attract any serious players. Enter ColdFusion. With this powerful and effective tool, I developed a program to monitor unique clicks (by IP address) on banner ads. Like any truly obsessive-compulsive developer, after I mastered this process I decided to take things a few steps further. I developed a tracking system not only to monitor banner clicks, but to count how often banners had been viewed. Once this was accomplished, I added logic to allow multiple banners to be displayed in rotation on a single page. The finished product can be called from any HTML page through a set of hyperlink and image tags, as follows:

<a href=http://www.YourDomain.com/click.
cfm?domain=Advertiser target=_top>
<img src=
http://www.YourDomain.com/rotate.cfm?
domain=Advertiser width=468 height=60
border=0 alt="Click Me">

The most important piece of information for advertisers is the number of times their ad has been clicked. Hence, the first piece of logic I developed was a banner-click program. This piece of code is structured around the <CFLOCATION> tag, which proved to be an extraordinarily effective tool not only in this module, but also in several others that I'll discuss in this article. In fact, the tag is the driving force behind this entire set of programs.

The beauty of the <CFLOCATION> tag, I discovered early on, is that it performs a "soft" redirect, i.e., it allows users to employ their [Back] key should they want to return to the originating page. Many other redirection vehicles, such as the HTML-based META/Refresh tag and the JavaScript LOCATION command, aren't quite so friendly, throwing users into a loop of sorts when they try to back out of a redirected page. Another nice feature of the tag is its ability (when combined with an HTML <IMG SRC> tag) to populate a small piece of a page - a subarea, so to speak - that could contain random banners. I'll discuss this functionality when I describe the banner-rotation logic.

Before any coding could take place, of course, I needed to design a small database to hold click-thru and page-view data. In addition, user IDs and passwords had to be set up to allow advertisers to log in and collect their real-time stats. I established the following three tables within an MS Access database: Clicks (Fields: StatDate, Domain, IP_Addr, Clicks), Views (Fields: StatDate, Domain, Views), and Users (Fields: User_id, Password). One row in the Users table must be populated with a password and user ID for each campaign that will be run through this set of programs. The user ID must be identical to the domain, described in the next paragraph, for the programs to start collecting statistics. For example, a user ID of "jane_doe" is used not only to log in but also to allow the code to identify the advertiser's target URL.

The first piece of code I'll discuss -- the click-thru logic --- works as follows: the advertiser's banner is hyperlinked to a program named click.cfm. Appended to the end of the string is a parameter called domain. Based on this parm, the program checks to see whether the domain has registered any clicks in the database via the SQL count() function. If prior clicks exist for the day, the program increments, by one, the Clicks field in the database. Otherwise the program inserts the first record into the database, recording the day, domain and IP address (#CGI.Remote_Addr# -- for later use in the statistical reporting piece).

<CFQUERY NAME="Checkit" DATASOURCE="AdKnt">
Select count(domain) as KntNum from Clicks
where domain = '#domain#' ...
<CFIF #Checkit.KntNum# GT 0>
<CFQUERY DATASOURCE="AdKnt">
Update Stats ...

<CFELSE>
<CFQUERY DATASOURCE="AdKnt">
Insert into Stats ...

Once the stats are recorded, the program uses the #domain# parm again in a <CFSWITCH> statement to determine what URL the user should be sent to by way of a <CFLOCATION> tag. (Although this parameter allows the program to process more than one domain, the code does limit the number of domains that can be handled per page to a single account. I'll discuss this further at the end of the article.) It should be noted that all the action takes place behind the scenes. It's seamless and transparent, the way click-thru programs were meant to be. I should mention that in a real-world scenario you'd want to modify much of the code I'm discussing to be table based. For the purpose of readability, I hard-coded all routines in this article.

< CFSWITCH expression=#domain#>
< CFCASE value=" Advertiser ">
<CFLOCATION url = "http://www.Advertiser.com/">
</ CFCASE >
< CFCASE value=" AdvertiserTwo ">
<CFLOCATION url = "http://www.AdvertiserTwo.com/.htm">...

Banner Rotation
The meatier code resides in the program's banner-rotation logic. The main trick to getting this piece of code to work lay in a combination of the HTML <IMG SRC> tag, ColdFusion's Rand-Range() function and, once again, the <CFLOCATION> tag.

Upon examining a few existing CGI-based banner programs, I noticed that the programs had stuffed CGI code into an <IMG SRC> tag, which, of course, is generally intended to fetch images and display them in browsers. All things being equal, I thought, if CGI programmers can do this, why couldn't a ColdFusion programmer? After some quick testing, I found that indeed I could. This simple discovery is the key to the banner program. I developed the rotation and page-viewing logic in two programs, aptly called rotate.cfm and views.cfm. Each time a browser loads a page containing the banner code, the rotate.cfm program is called. This program uses ColdFusion's RandRange() function to determine a random number, and then uses the #inum# parameter to pass the value to the views.cfm program (along with the domain name parameter from the <IMG SRC> tag). The program writes the entire URL string to a variable using <CFSET> and then plugs the variable into the <CFLOCATION> tag. Why, you may ask, didn't I incorporate this logic into one source file? The simple answer is, originally I did but the program didn't work. Hence, I segregated the logic, whereupon it worked like a charm.

<CFSET #RandNum# = #randrange(1,10)#>
<CFOUTPUT>
<CFSET #URLstr# = 'http://www.YourDomain.com/views.cfm?inum=' &
'#RandNum#' & '&domain=' & '#domain#'>
<CFLOCATION URL=#URLstr#>
</CFOUTPUT>

Note: I should advise that you "seed" the RandRange() function with the Randomize() function since just about every manual I've read tells you to do so. Why RandRange() isn't smart enough to seed itself remains just one more great mystery of life.

Similar to the click program, the first thing that views.cfm does is make a record of the fact that the banner has been viewed on a page (known in Web lingo as a "hit"). You may note that I chose not to record the IP address along with the other page-view information. I did this to avoid creating a process that would quickly accumulate volumes of records into my database. (Instead of incrementing a counter field, each new page view would have generated a new record.) In a real-world scenario, however, you may want to include this piece of information since many advertisers request it - they tend to be a very demanding group.

Once the views.cfm collects all appropriate statistics, based on the #domain# parameter, it then performs its final task: determining which banner to display. First, the program examines the #domain# parm to identify the suite of banners from which it will make a selection; then it employs the #inum# parm passed from the rotate.cfm to isolate the choice to a single banner.

The program sends the #inum# parameter to a <cfswitch> tag and uses our old friend <cflocation> to deliver the graphic to the page. In this case the tag populates a small piece of the browser's window instead of actually navigating the session to a whole new page. Put simply, <CFLOCATION> is a nice piece of work.

<CFIF #domain#' eq Advertiser'>
<CFSWITCH expression=#inum#>
<CFCASE value="1">
< CFLOCATION url = "http://www.YourDomain.com/banner.gif">
</ CFCASE > ...

As we all know, anything that moves on the Web makes a big splash in the viewer community. (The first person to put a full-scale Chevy commercial on the Internet will no doubt be touted as a genius.) But while rotating banners may be fun to observe, they're not worth much without a statistical reporting package to provide advertisers with crucial data showing how many people are viewing and clicking their ads. Hence the KntRpt.cfm.,p> The first thing the stats program does is request a user ID and password from the viewer in login.cfm, which then passes control to the statistical reporting module, KntRpt.cfm. By making the user ID identical to the #domain# parameter used in the rotation and click code, this program is able to use the advertiser's user ID to access a set of data that pertains to his or her account. It then displays the account's daily, monthly and inception-to-date page views and clicks. In addition, since we have diligently stored IP information with each click record, the stats program is able to determine which clicks are unique and which have been generated by a user who is enamored of his left mouse key. An example of the click section of the report is displayed in Figure 1.

The program distinguishes between nonunique and unique clicks as follows: to calculate the former, the program just uses the SQL Count() function to add the number in the Clicks field, based on a given grouping as described above. To collect clicks by unique IP, the program counts the IP_Addr field instead. For example, if IP address 123.1.123.12 is clicked 202 times on May 12 (see Figure 2), it's only counted as one unique click (since it resides in a single record for that day). It counts as 202 nonunique clicks, however, since that's the value stored in the Clicks field.

To keep the report somewhat brief, the program limits daily stats to the current month only via a combination of ColdFusion's month() and now() functions in the SQL WHERE clause. For previous months it collects a cumulative number in one row by grouping on the month() function. For an inception-to-date number it simply eliminates all date screening from the SQL statement.

WHERE clause from daily report:
"WHERE Month(StatDate) =
Month(Now())..." GROUP clause from monthly report:
"GROUP by Month(StatDate) ..."

Page views are collected in a manner similar to that for click-thru stats; the exception is that in our current scenario we don't distinguish between unique and nonunique views. Once the SQL statements have populated all their respective buckets, the data is presented to the user via some simple HTML tables. To prevent ColdFusion from spilling error code onto the viewer's screen, if a campaign has yet to accumulate any clicks or views, the program wraps a couple of conditionals around the display code to ensure that the buckets are greater than zero before writing them to the page.

Currently the banner program handles one domain at a time by using the #domain# parameter to isolate a particular account. No doubt some readers will wonder why I didn't take my code one step further and design a way for the program to accommodate multiple domains within a single page, the way the large networks (DoubleClick, 24/7, BURST!, etc.) do. This would entail eliminating the domain parm and rotating not only single banners but multiple suites of banners, with each suite representing a different advertiser.

The simple answer is to use cookies the way the big boys do (AdForce, DoubleClick DART, et al.). This has become the de facto standard for addressing the stateless nature of the Web and it applies to this scenario as well. At the time of this writing I hadn't included this functionality, but look for it in my next article.

More Stories By Stuart Newman

Stuart Newman is the owner and operator of NY Rock (nyrock.com),
a New York-based
entertainment site.
In addition, he's
president of the
consulting firm of Scott Commmunications Inc., and a partner in
ECMedia.net, an Internet advertising start-up
venture.

Comments (1) View Comments

Share your thoughts on this story.

Add your comment
You must be signed in to add a comment. Sign-in | Register

In accordance with our Comment Policy, we encourage comments that are on topic, relevant and to-the-point. We will remove comments that include profanity, personal attacks, racial slurs, threats of violence, or other inappropriate material that violates our Terms and Conditions, and will block users who make repeated violations. We ask all readers to expect diversity of opinion and to treat one another with dignity and respect.


Most Recent Comments
Scott 05/16/03 11:26:00 AM EDT

this is a test....

@ThingsExpo Stories
In his Opening Keynote at 21st Cloud Expo, John Considine, General Manager of IBM Cloud Infrastructure, led attendees through the exciting evolution of the cloud. He looked at this major disruption from the perspective of technology, business models, and what this means for enterprises of all sizes. John Considine is General Manager of Cloud Infrastructure Services at IBM. In that role he is responsible for leading IBM’s public cloud infrastructure including strategy, development, and offering m...
DXWorldEXPO LLC announced today that All in Mobile, a mobile app development company from Poland, will exhibit at the 22nd International CloudEXPO | DXWorldEXPO. All In Mobile is a mobile app development company from Poland. Since 2014, they maintain passion for developing mobile applications for enterprises and startups worldwide.
DXWorldEXPO LLC announced today that ICC-USA, a computer systems integrator and server manufacturing company focused on developing products and product appliances, will exhibit at the 22nd International CloudEXPO | DXWorldEXPO. DXWordEXPO New York 2018, colocated with CloudEXPO New York 2018 will be held November 11-13, 2018, in New York City. ICC is a computer systems integrator and server manufacturing company focused on developing products and product appliances to meet a wide range of ...
We are seeing a major migration of enterprises applications to the cloud. As cloud and business use of real time applications accelerate, legacy networks are no longer able to architecturally support cloud adoption and deliver the performance and security required by highly distributed enterprises. These outdated solutions have become more costly and complicated to implement, install, manage, and maintain.SD-WAN offers unlimited capabilities for accessing the benefits of the cloud and Internet. ...
Headquartered in Plainsboro, NJ, Synametrics Technologies has provided IT professionals and computer systems developers since 1997. Based on the success of their initial product offerings (WinSQL and DeltaCopy), the company continues to create and hone innovative products that help its customers get more from their computer applications, databases and infrastructure. To date, over one million users around the world have chosen Synametrics solutions to help power their accelerated business or per...
Founded in 2000, Chetu Inc. is a global provider of customized software development solutions and IT staff augmentation services for software technology providers. By providing clients with unparalleled niche technology expertise and industry experience, Chetu has become the premiere long-term, back-end software development partner for start-ups, SMBs, and Fortune 500 companies. Chetu is headquartered in Plantation, Florida, with thirteen offices throughout the U.S. and abroad.
Dion Hinchcliffe is an internationally recognized digital expert, bestselling book author, frequent keynote speaker, analyst, futurist, and transformation expert based in Washington, DC. He is currently Chief Strategy Officer at the industry-leading digital strategy and online community solutions firm, 7Summits.
Bill Schmarzo, author of "Big Data: Understanding How Data Powers Big Business" and "Big Data MBA: Driving Business Strategies with Data Science," is responsible for setting the strategy and defining the Big Data service offerings and capabilities for EMC Global Services Big Data Practice. As the CTO for the Big Data Practice, he is responsible for working with organizations to help them identify where and how to start their big data journeys. He's written several white papers, is an avid blogge...
I think DevOps is now a rambunctious teenager - it's starting to get a mind of its own, wanting to get its own things but it still needs some adult supervision," explained Thomas Hooker, VP of marketing at CollabNet, in this SYS-CON.tv interview at DevOps Summit at 20th Cloud Expo, held June 6-8, 2017, at the Javits Center in New York City, NY.
"MobiDev is a software development company and we do complex, custom software development for everybody from entrepreneurs to large enterprises," explained Alan Winters, U.S. Head of Business Development at MobiDev, in this SYS-CON.tv interview at 21st Cloud Expo, held Oct 31 – Nov 2, 2017, at the Santa Clara Convention Center in Santa Clara, CA.
Major trends and emerging technologies – from virtual reality and IoT, to Big Data and algorithms – are helping organizations innovate in the digital era. However, to create real business value, IT must think beyond the ‘what’ of digital transformation to the ‘how’ to harness emerging trends, innovation and disruption. Architecture is the key that underpins and ties all these efforts together. In the digital age, it’s important to invest in architecture, extend the enterprise footprint to the cl...
Data is the fuel that drives the machine learning algorithmic engines and ultimately provides the business value. In his session at Cloud Expo, Ed Featherston, a director and senior enterprise architect at Collaborative Consulting, discussed the key considerations around quality, volume, timeliness, and pedigree that must be dealt with in order to properly fuel that engine.
Two weeks ago (November 3-5), I attended the Cloud Expo Silicon Valley as a speaker, where I presented on the security and privacy due diligence requirements for cloud solutions. Cloud security is a topical issue for every CIO, CISO, and technology buyer. Decision-makers are always looking for insights on how to mitigate the security risks of implementing and using cloud solutions. Based on the presentation topics covered at the conference, as well as the general discussions heard between sessio...
IoT is rapidly becoming mainstream as more and more investments are made into the platforms and technology. As this movement continues to expand and gain momentum it creates a massive wall of noise that can be difficult to sift through. Unfortunately, this inevitably makes IoT less approachable for people to get started with and can hamper efforts to integrate this key technology into your own portfolio. There are so many connected products already in place today with many hundreds more on the h...
No hype cycles or predictions of zillions of things here. IoT is big. You get it. You know your business and have great ideas for a business transformation strategy. What comes next? Time to make it happen. In his session at @ThingsExpo, Jay Mason, Associate Partner at M&S Consulting, presented a step-by-step plan to develop your technology implementation strategy. He discussed the evaluation of communication standards and IoT messaging protocols, data analytics considerations, edge-to-cloud tec...
DXWorldEXPO LLC announced today that the upcoming DXWorldEXPO | CloudEXPO New York event will feature 10 companies from Poland to participate at the "Poland Digital Transformation Pavilion" on November 12-13, 2018.
Digital Transformation is much more than a buzzword. The radical shift to digital mechanisms for almost every process is evident across all industries and verticals. This is often especially true in financial services, where the legacy environment is many times unable to keep up with the rapidly shifting demands of the consumer. The constant pressure to provide complete, omnichannel delivery of customer-facing solutions to meet both regulatory and customer demands is putting enormous pressure on...
CloudEXPO | DXWorldEXPO are the world's most influential, independent events where Cloud Computing was coined and where technology buyers and vendors meet to experience and discuss the big picture of Digital Transformation and all of the strategies, tactics, and tools they need to realize their goals. Sponsors of DXWorldEXPO | CloudEXPO benefit from unmatched branding, profile building and lead generation opportunities.
The best way to leverage your CloudEXPO | DXWorldEXPO presence as a sponsor and exhibitor is to plan your news announcements around our events. The press covering CloudEXPO | DXWorldEXPO will have access to these releases and will amplify your news announcements. More than two dozen Cloud companies either set deals at our shows or have announced their mergers and acquisitions at CloudEXPO. Product announcements during our show provide your company with the most reach through our targeted audienc...
Everything run by electricity will eventually be connected to the Internet. Get ahead of the Internet of Things revolution. In his session at @ThingsExpo, Akvelon expert and IoT industry leader Sergey Grebnov provided an educational dive into the world of managing your home, workplace and all the devices they contain with the power of machine-based AI and intelligent Bot services for a completely streamlined experience.