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

时间:2021-07-14 15:44:32

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

最近在我的MVC项目中出现了两个非常小,但是往往惹出大麻烦的问题,借中午的时间在这里记录一下。

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

二:由于使用的是Iframe框架,同时也加入了session超时重新登录的限制,但登录页面会出现在Center中,十分尴尬。

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

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

所以在这里建议大家,为了避免出现无厘头的事情,还是不要偷懒。现在来看看MSDN对UrlEncode和UrlDecode的解释。

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

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

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

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

针对第二个问题,相对的就简单了,只需要在Login页面中做判断就行了。具体代码如下:

<script language="javascript" type="text/javascript">
    if (window != top)
        top.location.href = location.href;
</script>