通过网上大量的搜索发现原来IE的iframe有特殊之处, 默认情况下, IE如果发现iframe的域和父页面的域不同, 则会禁止iframe页面写入Cookie(Session在默认情况下就是通过Cookie保存一个SessionID的). 如果将IE设置->隐私的级别调至最低, 也就是接受任何Cookie, 那么是运行正常的.
解决办法
在IIS的 HTTP Response Headers 中添加一行, 名字为: p3p, 值设置为: CP="IDC DSP COR CURa ADMa OUR IND PHY ONL COM STA"
参考
1. http://stackoverflow.com/questions/6368750/session-variables-not-saved-when-page-is-in-an-iframe
2. http://aspnetresources.com/blog/frames_webforms_and_rejected_cookies
3. http://support.microsoft.com/kb/283185/zh-cn