Click here to close now.




















Welcome!

You will be redirected in 30 seconds or close now.

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

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
For IoT to grow as quickly as analyst firms’ project, a lot is going to fall on developers to quickly bring applications to market. But the lack of a standard development platform threatens to slow growth and make application development more time consuming and costly, much like we’ve seen in the mobile space. In his session at @ThingsExpo, Mike Weiner, Product Manager of the Omega DevCloud with KORE Telematics Inc., discussed the evolving requirements for developers as IoT matures and conducted a live demonstration of how quickly application development can happen when the need to comply wit...
Explosive growth in connected devices. Enormous amounts of data for collection and analysis. Critical use of data for split-second decision making and actionable information. All three are factors in making the Internet of Things a reality. Yet, any one factor would have an IT organization pondering its infrastructure strategy. How should your organization enhance its IT framework to enable an Internet of Things implementation? In his session at @ThingsExpo, James Kirkland, Red Hat's Chief Architect for the Internet of Things and Intelligent Systems, described how to revolutionize your archit...
SYS-CON Events announced today that HPM Networks will exhibit at the 17th International Cloud Expo®, which will take place on November 3–5, 2015, at the Santa Clara Convention Center in Santa Clara, CA. For 20 years, HPM Networks has been integrating technology solutions that solve complex business challenges. HPM Networks has designed solutions for both SMB and enterprise customers throughout the San Francisco Bay Area.
MuleSoft has announced the findings of its 2015 Connectivity Benchmark Report on the adoption and business impact of APIs. The findings suggest traditional businesses are quickly evolving into "composable enterprises" built out of hundreds of connected software services, applications and devices. Most are embracing the Internet of Things (IoT) and microservices technologies like Docker. A majority are integrating wearables, like smart watches, and more than half plan to generate revenue with APIs within the next year.
The Internet of Everything (IoE) brings together people, process, data and things to make networked connections more relevant and valuable than ever before – transforming information into knowledge and knowledge into wisdom. IoE creates new capabilities, richer experiences, and unprecedented opportunities to improve business and government operations, decision making and mission support capabilities.
Growth hacking is common for startups to make unheard-of progress in building their business. Career Hacks can help Geek Girls and those who support them (yes, that's you too, Dad!) to excel in this typically male-dominated world. Get ready to learn the facts: Is there a bias against women in the tech / developer communities? Why are women 50% of the workforce, but hold only 24% of the STEM or IT positions? Some beginnings of what to do about it! In her Opening Keynote at 16th Cloud Expo, Sandy Carter, IBM General Manager Cloud Ecosystem and Developers, and a Social Business Evangelist, d...
In his keynote at 16th Cloud Expo, Rodney Rogers, CEO of Virtustream, discussed the evolution of the company from inception to its recent acquisition by EMC – including personal insights, lessons learned (and some WTF moments) along the way. Learn how Virtustream’s unique approach of combining the economics and elasticity of the consumer cloud model with proper performance, application automation and security into a platform became a breakout success with enterprise customers and a natural fit for the EMC Federation.
The Internet of Things is not only adding billions of sensors and billions of terabytes to the Internet. It is also forcing a fundamental change in the way we envision Information Technology. For the first time, more data is being created by devices at the edge of the Internet rather than from centralized systems. What does this mean for today's IT professional? In this Power Panel at @ThingsExpo, moderated by Conference Chair Roger Strukhoff, panelists addressed this very serious issue of profound change in the industry.
Discussions about cloud computing are evolving into discussions about enterprise IT in general. As enterprises increasingly migrate toward their own unique clouds, new issues such as the use of containers and microservices emerge to keep things interesting. In this Power Panel at 16th Cloud Expo, moderated by Conference Chair Roger Strukhoff, panelists addressed the state of cloud computing today, and what enterprise IT professionals need to know about how the latest topics and trends affect their organization.
It is one thing to build single industrial IoT applications, but what will it take to build the Smart Cities and truly society-changing applications of the future? The technology won’t be the problem, it will be the number of parties that need to work together and be aligned in their motivation to succeed. In his session at @ThingsExpo, Jason Mondanaro, Director, Product Management at Metanga, discussed how you can plan to cooperate, partner, and form lasting all-star teams to change the world and it starts with business models and monetization strategies.
Converging digital disruptions is creating a major sea change - Cisco calls this the Internet of Everything (IoE). IoE is the network connection of People, Process, Data and Things, fueled by Cloud, Mobile, Social, Analytics and Security, and it represents a $19Trillion value-at-stake over the next 10 years. In her keynote at @ThingsExpo, Manjula Talreja, VP of Cisco Consulting Services, discussed IoE and the enormous opportunities it provides to public and private firms alike. She will share what businesses must do to thrive in the IoE economy, citing examples from several industry sectors.
There will be 150 billion connected devices by 2020. New digital businesses have already disrupted value chains across every industry. APIs are at the center of the digital business. You need to understand what assets you have that can be exposed digitally, what their digital value chain is, and how to create an effective business model around that value chain to compete in this economy. No enterprise can be complacent and not engage in the digital economy. Learn how to be the disruptor and not the disruptee.
Akana has released Envision, an enhanced API analytics platform that helps enterprises mine critical insights across their digital eco-systems, understand their customers and partners and offer value-added personalized services. “In today’s digital economy, data-driven insights are proving to be a key differentiator for businesses. Understanding the data that is being tunneled through their APIs and how it can be used to optimize their business and operations is of paramount importance,” said Alistair Farquharson, CTO of Akana.
Business as usual for IT is evolving into a "Make or Buy" decision on a service-by-service conversation with input from the LOBs. How does your organization move forward with cloud? In his general session at 16th Cloud Expo, Paul Maravei, Regional Sales Manager, Hybrid Cloud and Managed Services at Cisco, discusses how Cisco and its partners offer a market-leading portfolio and ecosystem of cloud infrastructure and application services that allow you to uniquely and securely combine cloud business applications and services across multiple cloud delivery models.
The enterprise market will drive IoT device adoption over the next five years. In his session at @ThingsExpo, John Greenough, an analyst at BI Intelligence, division of Business Insider, analyzed how companies will adopt IoT products and the associated cost of adopting those products. John Greenough is the lead analyst covering the Internet of Things for BI Intelligence- Business Insider’s paid research service. Numerous IoT companies have cited his analysis of the IoT. Prior to joining BI Intelligence, he worked analyzing bank technology for Corporate Insight and The Clearing House Payment...
"Optimal Design is a technology integration and product development firm that specializes in connecting devices to the cloud," stated Joe Wascow, Co-Founder & CMO of Optimal Design, in this SYS-CON.tv interview at @ThingsExpo, held June 9-11, 2015, at the Javits Center in New York City.
SYS-CON Events announced today that CommVault has been named “Bronze Sponsor” of SYS-CON's 17th International Cloud Expo®, which will take place on November 3–5, 2015, at the Santa Clara Convention Center in Santa Clara, CA. A singular vision – a belief in a better way to address current and future data management needs – guides CommVault in the development of Singular Information Management® solutions for high-performance data protection, universal availability and simplified management of data on complex storage networks. CommVault's exclusive single-platform architecture gives companies unp...
Electric Cloud and Arynga have announced a product integration partnership that will bring Continuous Delivery solutions to the automotive Internet-of-Things (IoT) market. The joint solution will help automotive manufacturers, OEMs and system integrators adopt DevOps automation and Continuous Delivery practices that reduce software build and release cycle times within the complex and specific parameters of embedded and IoT software systems.
"ciqada is a combined platform of hardware modules and server products that lets people take their existing devices or new devices and lets them be accessible over the Internet for their users," noted Geoff Engelstein of ciqada, a division of Mars International, in this SYS-CON.tv interview at @ThingsExpo, held June 9-11, 2015, at the Javits Center in New York City.
Internet of Things is moving from being a hype to a reality. Experts estimate that internet connected cars will grow to 152 million, while over 100 million internet connected wireless light bulbs and lamps will be operational by 2020. These and many other intriguing statistics highlight the importance of Internet powered devices and how market penetration is going to multiply many times over in the next few years.