日期:2014-05-16  浏览次数:20416 次

JavaScript如何控制Session

        看到这个题目,或许有人会提出疑问,JavaScript代表客户端,而Session代表的是服务器(不知道这样说大家是否能够理解)。

        先说一下需求,我在做一个权限管理的时候,需要在点击某个模块时,Session中相应的改变模块代号,而实现这个操作的是一个a标签,当然我不知道 一个linkbutton是否可以同时将跳转页面和修改Session做了,个人感觉应该是可以的,具体能不能,如果有人做了Demo可以留言说明。

        a标签,实现页面的跳转,他的onclick事件,执行的也是本页面中的js方法,现在就回到了题目所描述的问题——写一个JavaScript方法,使其修改Session。

        其实这个例子不难,但是对我个人的意义却非同寻常,这个例子解除了我一大部分对AJAX的恐惧。

        首先,是写一个一般处理程序(也就是服务端代码)

        需要说明的是,如果要修改Session,需要额外引入命名空间,和实现一个接口(只需实现,别的什么也不用做)        

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.SessionState;

namespace TGB.CJX
{
    /// <summary>
    /// 修改Session
    /// </summary>
    public class ModifySession : IHttpHandler,IRequiresSessionState
    {

        public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            context.Session["modelID"]=context.Request.QueryString["session"].ToString();
            //context.Session["modelID"] = "1";
            //context.Response.Write(context.Session["modelID"]);

        }

        public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

        有没有发现上面实现的功能很简单呢?

        下面,是客户端代码

        var xmlhttp;
        var session;
        function submit(obj) {
            //session = obj.id.substr(1, 1);
            session = obj.id.replace("model","");
            //IE7,IE8,FF,MOZILLA,SAFARI
            if (window.XMLHttpRequest) {
                //alert("IE7,IE8,FF,MOZILLA,SAFARI");
                xmlhttp = new XMLHttpRequest();
                if (xmlhttp.overrideMinmeType) {
                    xmlhttp.overrideMinmeType("text/xml");
                }
            } else if (window.ActiveXObject) {
                //alert("IE5,IE6");
                var activeName = ["MSXML2.XMLHTTP", "Miscrosoft.XMLHTTP"];

                for (var i = 0; i < activeName.length; i++) {
                    try {
                        xmlhttp = new ActiveXObject(activeName[i]);
                        break;
                    } catch (e) {
                        return;
                    }
                }
            }

            if (xmlhttp == undefined || xmlhttp == null) {
                alert("当前浏览器不支持创建XMLHTTPREQUEST对象,请更换浏览器");
                return;
            }

            xmlhttp.onreadystatechange = callback;

            xmlhttp.open("GET", "ModifySession.ashx?session=" + session, true);
            xmlhttp.send(null);
        }

        function callback() {
            //判断和服务器的交互是否完成,还要判断服务器端是否返回了数据
            if (xmlhttp.readyState == 4) {
                //表示和服务器端的交互完成
                if (xmlhttp.status == 200) {
                    //alert("正确返回了数据");
                    return;
                }
            }
        }

        在回调函数中,我只写了一个测试正常返回数据的语句,后来注释掉了。

        在为a标签绑定事件时,我最初用的是拼接字符串的方法,就是从数据库中查到模块ID和模块名称,然后通过下面的一条语句进行语句拼接: