This is a real-life example of exploiting a web application security flaw. I received an email from Discover Card offering some Lowe's coupons.
data:image/s3,"s3://crabby-images/aa33a/aa33aa4cf70794046d4858d9bb0d81bd3e8f3dcf" alt=""
I was needing to buy some stuff there anyway, so I decided to grab them.
data:image/s3,"s3://crabby-images/21bf5/21bf5a11f73c226d3b83bcb729242ca640bf09c2" alt=""
I was soon shocked and amazed. Turns out they expect you to download an executable (something called a"Coupon Print Activator") and run it just to print the coupons.
data:image/s3,"s3://crabby-images/27d55/27d55319ca3d972cf1b73841b80628f18c2e5b08" alt=""
I am not in the habit of running strange .exe's.
data:image/s3,"s3://crabby-images/a6345/a6345f12c2a7a4bc628dc0cb556d0e397ad10c02" alt=""
But, I really wanted those coupons (and perhaps sensed my hacking skillz were being challenged). I looked at the requests being made to the server, and noticed that dsppreprint.cfm had some JavaScript pointing to interesting URLs, one to "print.cfm" and one to "print_noplugin_redirect.cfm". The query strings were radically different between the two, so I decided to append the query string from print.cfm onto the other .cfm file.
data:image/s3,"s3://crabby-images/21548/215481ddd1052f6b97656ee3ef6e3eed1651b390" alt=""
This hybrid URL ended up in a round-about way returning some HTML with an "embed" tag with a bunch of attributes. One of the attributes was very interesting to me.
data:image/s3,"s3://crabby-images/4154b/4154ba1c010ac5f9578de3ac3cbb3f433e148fd7" alt=""
A request to this URL returned some raw data that appeared to be meant for consumption by the Coupon Print Activator. It also led me to discover yet another URL.
data:image/s3,"s3://crabby-images/fd6b9/fd6b978962b01514b5732e1499550f2e56109f78" alt=""
A request to this URL returned the following jpeg image (numbers masked to protect something or other):
data:image/s3,"s3://crabby-images/c7539/c75392d3f8dd6e14d8e32498a086b0602bdcc7d7" alt=""
So I got a bar code. Wonder if I could print this bar code and use it at the self-checkout at Lowe's? This would not be unethical as I was entitled to the coupon anyway. I just didn't want ro run that Activator thingy! As a simple test, I jumped over to
Lowes.com and added a ceiling fan to my shopping cart. There was an input field for "Promotional Code".
data:image/s3,"s3://crabby-images/3a3ee/3a3ee1fe46b205cffb854af5ca458f1d9bc29b7e" alt=""
Proceeding to enter the number that appeared below my bar code, I was pleased to see my $10.00 discount applied.
data:image/s3,"s3://crabby-images/9d302/9d30290080eaf8b3913815d1ad6da0f52aac4973" alt=""
To sum up, coupon obtained, Activator thingy bypassed. Sorry I do not have time get into how this site could have been written more securely. Suffice it to say that exposing data, URLs, and client side logic is not good.