URLStream, Adobe AIR and FLEX security permission issues on Windows 7

I had a particularly vexing problem that took nearly a half a day to dig to the bottom of. I was successfully able to connect to a streaming API using Adobe’s URLStream class, and I could see the passing of packets back-and-forth between the client app and the remote server using WireShark. So, there was definitely a valid connection and hand-shaking happening in the background. And, another key piece to the puzzle was the app ran just fine as a Flex app using the default bin-debug run-time settings. But, other than that running it as an AIR app or a Flex app from IIS, I simply couldn’t get any of the URLStream event listeners to acknowledge any type of connection whatsoever.

I knew this was a permissions issue, but finding documentation on AIR and Flash runtime permissions is, well, not easy. So, after quite a few searches on the internet and many dead-ends, there buried deep in some ancient scrolls of Adobe documentation were a few articles that provided the key to finally unlock the treasure chest.

You may have never heard about it before, but there is a User Flash Player Trust directory that typically contains at least one configuration file. And, in those files you can specifically grant application access to a particularly directory. In theory, there is also a Global Flash Player Trust directory. I originally thought I made the changes to that, but actually I never was able to locate it, and I ran out of time anyway. So, if someone knows where that is on Windows 7 please let me know.

Solution:

I added the pathname to the AIR executable installation directory to the air.1.0.trust.cfg file and bingo the application worked as expected.

The file typically resides in a path that looks like this: C:\Users\<username>\AppData\Roaming\Macromedia\Flash Player\#Security\FlashPlayerTrust

And, I add the following line to the file: C:\Program Files (x86)\BasicStreams.

References:

[Flash Player] Administrator Controls

[Flash Player] User Control document

Adobe Online Doc – Restricting Network APIs

Mobile Internet Bandwidth Usage

As U.S. broadband providers move towards metering everyone’s internet usage it pays to have a basic understanding of how your surfing habits add up. Using a borrowed Verizon VZAccess card for my laptop last week, I noticed every time I logged onto the service it gave an update on how much data I had consumed in the previous session.  I was quite surprised at the amount I used per session. And going over your plan can be painful. Verizon, for example, has one plan that charges $20 for each additional Gigabyte (GB) once you go over your 1st GB.

So, I decided to put firebug to work and take a few measurements of my own.  Full, non-mobile, web pages can add up in size really quick. Check out the sizes of these pages:

  1. Computerworld – 541K
  2. MSNBC – 1MB
  3. MSDN Home page – 423K
  4. Youtube video – 20.9 MBs (~6 mins)

So how about some tools to help out? Verizon provides a nice online planning tool to help you gauge how much data you might use: https://www.verizonwireless.com/splash_includes/datacalculator.html . Give it a shot, I think you’ll be surprised at just how fast the data (and charges) could add up.

As far as running a usage monitor on your droid (or iPhone), I don’t really have any recommendations yet, since I just started digging into this. I’ve tried Network Monitor, but it didn’t work on my Motorola Atria. I’m currently trying the free version of PhoneUsage. So, if you have some suggestions post a comment. If I can compile enough useful and interesting information I’ll write an updated blog post.

Running .ashx files on IIS 7, Windows 7 and .NET 4

If you simply copy your Visual Studio 2010 generic handler (.ashx) project’s directory into a virtual directory on IIS it will fail with an error similar to the following:

Description: An error occurred during the parsing of a resource required to service this request. Please review the following specific parse error details and modify your source file appropriately.

Parser Error Message: Could not create type ‘HealthCheck.health’.

There are lots of suggestions on the internet, but the most fundamental fix is hard to find. I know because I’ve run into this problem before and it took me quite a while to figure it out. This time I only wasted a half-an-hour before a little voice in my head reminded me that generic handlers created in Visual Studio 2010 require that they be run as an application in IIS.

So here’s how you do set up IIS to run the .ashx file as an application:

  1. Open  Internet Information Services (IIS) Manager
  2. Double-click on “Application Pools”. If your Default App Pool is not set to v4.0 then double click on it and change the version. If you don’t have v4.0 installed, then you’ll you need to do so. NOTE: if you change this be sure to test your other/older applications to make sure they don’t break. If they do break other apps, then right click below the Application Pool table and create a new, custom app pool using .NET v4.0.
  3. Right click “Default Web Site”
  4. Select “Add Application”
  5. Fill in all the Alias and Physical Path fields. BE SURE to select the correct application pool referenced in step 2!!

Extras

  1. Here’ s a great blog post on how find your .NET version that’s being used: https://www.walkernews.net/2008/05/16/how-to-check-net-framework-version-installed/ .
  2. You can also look at the bottom of the Parser Error Message and you’ll see the .NET version there, as well.