当前位置: 首页 > 图文教程 > 网络编程 > ASP > 轻松检测浏览器是否接受Cookies信息

ASP
查询翻页优化
强制刷新和判断文件地址
asp缓存类
Byval与Byref的区别
全面认识ASP注入技巧
ubbcode函数
newasp中下载类
[ASP]精华代码
由给定的字符串生成关键字
经验几则
转换中文为unicode 转换unicode到正常文本
在ASP应用程序中限制重复提交同一表单
ASP 程序实现自动升级功能
在ASP编程中使用数组
asp组件编写准备工作
利用AdoDb.Stream对象来读取UTF-8格式的文本文件
把字符串转换成数据库SQL语句格式
access中链接表的问题
access数据库的一些少用操作,ASP,创建数据库文件,创建表,创建字段,ADOX
Asp Access 创建静态文件/HTML

ASP 中的 轻松检测浏览器是否接受Cookies信息


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-08-14   浏览: 248 ::
收藏到网摘: n/a

  一种确定浏览器是否接受 Cookie 的方法是先编写一个 Cookie,然后再尝试读取这个 Cookie。如果不能读取这个 Cookie,则可以认为该浏览器不接受 Cookie。

  我编写了一个简单的示例来说明如何测试 Cookie 是否被接受。该示例包含两个页面。在第一个页面中,我编写了一个 Cookie,然后把浏览器重新定向到第二个页面。第二个页面尝试读取这个 Cookie,转而将浏览器重新定向到第一个页面,并向 URL 添加一个带有测试结果的查询字符串变量。

  第一个页面的代码如下:

protected System.Web.UI.WebControls.Label labelAcceptsCookies;
 
  private void Page_Load(object sender, System.EventArgs e)
  ...{
  
   if(!IsPostBack)
   ...{
    WriteCookie();
   
   }
  }

  private void  WriteCookie()
  ...{
   if( Request.QueryString["AcceptsCookies"] ==null)
   ...{
    Response.Cookies["TestCookie"].Value = "ok";
    Response.Cookies["TestCookie"].Expires = DateTime.Now.AddMinutes(1);
    Response.Redirect("CookieRead.aspx?redirect="+Server.UrlEncode(Request.Url.ToString()));
   }
   else
   ...{
    labelAcceptsCookies.Text = "接受 Cookie = "+Request.QueryString["AcceptsCookies"];
   }
  }
  第一个页面测试是否有回信,如果没有,就搜索包含测试结果的查询字符串变量 (AcceptsCookies)。如果没有找到查询字符串变量,则表示测试还没有完成,代码就写出一个名为“TestCookie”的 Cookie。写出 Cookie 之后,示例调用 Response.Redirect 来切换到测试页面 (TestForCookies.aspx)。附加到测试页面的 URL 的是名为 redirect 的查询字符串变量,该变量中包含了当前页面的 URL,这样就能在执行测试后把重定向到该页面。

  测试页面可以完全由代码组成,不需要包含控件。以下就是使用的代码:

private void Page_Load(object sender, System.EventArgs e)
  ...{
   ReadCookie();
  }
  private void ReadCookie()
  ...{
   String redirect  = Request.QueryString["redirect"];
   String acceptsCookies ;
   // 是否接受 Cookie?
   if(Request.Cookies["TestCookie"] ==null)
    // 没有 Cookie,因此不需要接受
    acceptsCookies = "0";
   else
   ...{
    acceptsCookies = "1";
    //删除测试 Cookie
    Response.Cookies["TestCookie"].Expires = DateTime.Now.AddDays(-1);
   }
   Response.Redirect(redirect + "?AcceptsCookies=" +acceptsCookies, true);
}

"