zoukankan      html  css  js  c++  java
  • Ajax.net控制Cookie和Session注意事项

    在ajax方法中往往需要验证用户身份等信息,此时通常需要读写session和cookie。在asp.net的ajax方法中读写session和cookie
    首先要注意的是ajax方法虽然写在网页中,在ide里自动完成工具也可以直接帮你写出Session[key]或者是Request.Cookie
    [key],但是这些肯定都不好用,因为ajax方法本身就相当于一个网页,他是通过了asp.net的handler截获一次http请求然后执行的代
    码。所以我们一定要使用HttpContext.Current来调用session和cookie。
    Cookie:
    HttpContext.Current.Response.Cookie[key]
    Session:
    HttpContext.Current.Session[key]
    使用上面的写法后,cookie已经可以读取了,但是发现session还是不行,调试发现居然HttpContext.Current.Session这个对象都是null。经过仔细调查才发现,原来ajax默认是不允许调用session的。
    我们的代码里的ajax方法前面有一个[Ajax.AjaxMethod()],这个AjaxMethod()里面原来是可以加参数的,根据大家使用的ajax组件的版本不同,参数是不同的,我使用的是ajax.net,居然有13种重载之多。
    这里面有一个参数类型是Ajax.HttpSessionStateRequirement,这种类型是枚举类,有三种值,分别为:
    None,Read,ReadWrite
    顾名思义,就是控制在这个ajax方法中是否可以调用session值得,所以我们只要将原来每个ajax方法中头上的[Ajax.AjaxMethod
    ()]换为[Ajax.AjaxMethod(Ajax.HttpSessionStateRequirement.Read)],就可以读取session了。

  • 相关阅读:
    oracle 闪回操作--区别于快照
    easyui 低版本下拉多选框绑定onChange事件样式失真问题
    kvm虚拟机网络配置-网桥
    CentOS7.5使用KVM创建虚拟机
    梦醒时分
    姑娘
    Ventoy+WePE 装机教程
    PG-SSL安全配置
    转载-如何做一份完善的补丁分析
    网络流24题部分题解
  • 原文地址:https://www.cnblogs.com/sleeper520/p/1320437.html
Copyright © 2011-2022 走看看