经典ASP和JQuery在重定向上重新加载default.asp页面

时间:2015-06-19 00:32:05

标签: javascript jquery vbscript asp-classic

我已经将现有的经典ASP网站与JQuery集成(之前他们使用的是VBScript)。以前的版本工作正常但脚本需要更新,因此它可以在其他浏览器上运行。但是当我使用集成的JQuery重定向页面时,系统会加载default.asp文件和第二个URL。地址栏还显示默认网址。

我该怎样防止这种情况?

当我使用window.open('url')时,它会打开包含正确网址的正确页面,但我打开了2个标签页。当我使用window.open('url', '_self')时,它仍然会重定向到有问题的页面。

P.S。 Response.Redirect 'url'window.open('url', '_self')会给出相同的结果。

编辑:这里有一些使用的代码

这里是在default.asp中加载的主框架JS(提交函数)

$("img[name=cmdLog]").click(function(){
            $("form[name=frmLogIn]").target = "_top";
            $("form[name=frmLogIn]").get(0).setAttribute("action", "ValidateUser.asp");
            $("form[name=frmLogIn]").submit();
        });

这里的ValidateUser.asp (没有更新的JS,仅使用VBScript)

<form name="frmValidate" method="post">
    <%
        Session("PMISConnString")="Provider=SQLOLEDB;Server=192.168.x.x;User ID=sa;PWD=x;Database=DB"
        dim conn, rsEmp, SQLQuery, m_Code,i,lenStr,newCode,rsUser
        set conn=Server.CreateObject("ADODB.Connection")

        m_Code=Request.Form("txtEmpID")
        lenStr=len(m_code)
        newCode=""
        for i=1 to lenStr
            if mid(m_Code,i,1)="'" then
                newCode=newCode & "''"
            else
                newCode=newCode & mid(m_Code,i,1)
            end if
        next 


        conn.Open=Session("PMISConnString")

        dim clsCrypt
        dim url
        set clsCrypt=Server.CreateObject("ChiperText.clsChiperText")

        SQLQuery="SELECT UserCode, Pwd "
        SQLQuery=SQLQuery & "FROM Users "
        SQLQuery=SQLQuery & "WHERE UserCode='" & clsCrypt.ChiperText(lcase(newCode)) & "'"

        set rsUser=Server.CreateObject("ADODB.Recordset")
        rsUser.Open SQLQuery,conn

        if rsUser.EOF then
            url = "ErrorPage.asp?TYPE=6"
        elseif rsUser.Fields("Pwd")<>clsCrypt.ChiperText(Request.Form("txtEmpPassword")) then
            url = "ErrorPage.asp?TYPE=7"
        end if

        SQLQuery="SELECT EmpID,EmpFirst,EmpLast,dbo.GetCapitalChars(Employee.EmpMid) AS MidInitial From Employee WHERE EmpID='" & newCode & "' "
        SQLQuery=SQLQuery & "AND EmpActive=1 "

        set rsEmp=Server.CreateObject("ADODB.Recordset")
        rsEmp.Open SQLQuery,conn
        if not rsEmp.EOF then
            Session("EmpID")=Request.Form("txtEmpID") 
            Session("MyName")=rsEmp.Fields("EmpFirst") & " " & rsEmp.Fields("MidInitial") & " " & rsEmp.Fields("EmpLast")
            'varServer="http://" + Request.ServerVariables("SERVER_NAME") + "/" + Session("VirtualName") + "/"

            Response.Cookies("Site")="http://" + Request.ServerVariables("SERVER_NAME") + "/" + "PMIS"

            Session("Server")="http://" + Request.ServerVariables("SERVER_NAME") + "/" + "PMIS"
            Session("ImgFolder")="http://" + Request.ServerVariables("SERVER_NAME") + "/" + "PMIS/Images/" 'full path ng images folder under PMIS directory
            url = "main2.asp"
        else
            url = "ErrorPage.asp?TYPE=1"
        end if

        Response.Redirect(url)
        rsEmp.Close
        Set rsEmp=Nothing
        set clsCrypt=Nothing
        conn.Close
        set conn=Nothing
    %>
</form>

1 个答案:

答案 0 :(得分:0)

如果在框架集中,请考虑使用JavaScript将window.top.location.href更改为重定向网址。