在ASP.NET开发中容易忽略的2个小问题

本文地址:http://www.cnblogs.com/outtamyhead/p/3642729.html,转载需保留本地址。javascript

最近在个人MVC项目中出现了两个很是小,可是每每惹出大麻烦的问题,借中午的时间在这里记录一下。html

一:在本地调试环境下可以正常读取Cookie,但发布到IIS中就不能读取,报空指针异常。java

二:因为使用的是Iframe框架,同时也加入了session超时从新登陆的限制,但登陆页面会出如今Center中,十分尴尬。cookie

针对第一个问题,主要的问题出如今对Cookie没有进行编码和解码。在没有这两个码的时候,读取Cookie的Value就会报空指针异常。因此,在使用Cookie的时候加上这两个码就行了。session

HttpCookie currentname = new HttpCookie("username", HttpUtility.UrlEncode(username));
//这段代码是在过滤器中写的
 string cookie_username = HttpUtility.UrlDecode(filterContext.RequestContext.HttpContext.Request.Cookies["username"].Value);

因此在这里建议你们,为了不出现无厘头的事情,仍是不要偷懒。如今来看看MSDN对UrlEncode和UrlDecode的解释。框架

须要注意的是,UrlEncode和UrlDecode要成对出现,这样才不会出现问题。编码

关于更多说明,请看园子里另外的文章点这里这里,两篇文章同样,可是不知道谁的是原版,o(╯□╰)ospa

针对第二个问题,相对的就简单了,只须要在Login页面中作判断就好了。具体代码以下:指针

<script language="javascript" type="text/javascript">
    if (window != top)
        top.location.href = location.href;
</script>
相关文章
相关标签/搜索