0

我用 javascript 编写了一个 web shell,但它在 firefox 中不起作用。但在 IE 和 Chrome 中,这很好。我发现在 Firefox 中我的脚本无法获取 keyevent。那么我该如何修复这个错误呢?非常感谢 :)

壳牌:http ://cdqzoi.com

脚本地址:http ://cdqzoi.com/console.js 下面的代码是上面脚本的一部分,处理keyevent。

this.keydown=function(){
    key=event;
    keyN=event.keyCode?event.keyCode:event.which?event.which:event.charCode;
    if(keyN==0)return;
    if((keyN==8)||(keyN==116)||(key.ctrlKey && keyN==82)){
        if(keyN==8 & !lock){
            this.command = this.command.substr(0,this.command.length-1);
            document.getElementById("console").innerHTML=getPrefix(this.transmit)+this.command;
        }
        try{
            event.returnValue=false;
            event.keyCode=0;
        }catch(e){
            event.preventDefault();
        }
    }
    keyN=0;
}
this.keypress=function(){
    key=event;
    keyN=event.keyCode?event.keyCode:event.which?event.which:event.charCode;
    if(keyN==0)return;
    if(!lock){
        if(keyN==13){
            if(this.transmit==0){
                user=this.command;
                document.getElementById("_console").innerHTML+=document.getElementById("console").innerHTML+"<br />";
                document.getElementById("console").innerHTML='';
                this.transmit=1;
                this.st=1;
            }else
            if(this.transmit==1){
                this.st=0;
                pass=this.command;
                document.getElementById("_console").innerHTML+=document.getElementById("console").innerHTML+"<br />";
                document.getElementById("console").innerHTML="";
                con.login(user,pass);
                try{
                    event.returnValue=false;
                    event.keyCode=0;
                }catch(e){
                    event.preventDefault();
                }
                keyN=0;
                return;
            }else
            if(this.transmit==2){con.execute(this.command);}
            this.command='';
        }else if(keyN==8){
        }else{
            this.command=this.command+String.fromCharCode(keyN);
        }
        if(this.st==0)document.getElementById("console").innerHTML=getPrefix(this.transmit)+this.command;
        else document.getElementById("console").innerHTML=getPrefix(1);
    }
    try{
        event.returnValue=false;
        event.keyCode=0;
    }catch(e){
        event.preventDefault();
    }
    keyN=0;
}
4

1 回答 1

0

像这样编写您的处理程序:

this.keypress = function(e) {
  var ev = window.event || e;
  // use ev from here onwards

原因是 IE(显然,Chrome 也选择通过全局变量而不是函数参数传递事件数据)。

于 2012-06-18T03:58:39.197 回答