⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 api_function.asp

📁 重庆宽频P2P电影小偷程序,可以做一个大型的电影站了
💻 ASP
字号:
<%
'******************************************************
'文件名: API_Function.asp
'描 述: 动易系统PDO远程接口函数文件
'版 本: 动易2006正式版及更高版本适用
'Copyright 2006 PowerEasy Inc. All Rights Reserved.
'Code Writer: EricWu (小李刀刀)
'******************************************************

Dim sMyXmlDoc, sMyXmlHTTP
'创建一个二维数组,将元素名和值存入其中
Redim sPE_Items(30,1)
sPE_Items(0,0) = "appid"
sPE_Items(1,0) = "action"
sPE_Items(2,0) = "syskey"
sPE_Items(3,0) = "status"
sPE_Items(4,0) = "message"
sPE_Items(5,0) = "username"
sPE_Items(6,0) = "password"
sPE_Items(7,0) = "email"
sPE_Items(8,0) = "question"
sPE_Items(9,0) = "answer"
sPE_Items(10,0) = "savecookie"
sPE_Items(11,0) = "truename"
sPE_Items(12,0) = "gender"
sPE_Items(13,0) = "birthday"
sPE_Items(14,0) = "qq"
sPE_Items(15,0) = "msn"
sPE_Items(16,0) = "mobile"
sPE_Items(17,0) = "telephone"
sPE_Items(18,0) = "address"
sPE_Items(19,0) = "zipcode"
sPE_Items(20,0) = "homepage"
sPE_Items(21,0) = "userip"
sPE_Items(22,0) = "jointime"
sPE_Items(23,0) = "experience"
sPE_Items(24,0) = "ticket"
sPE_Items(25,0) = "valuation"
sPE_Items(26,0) = "balance"
sPE_Items(27,0) = "posts"
sPE_Items(28,0) = "userstatus"
sPE_Items(29,0) = "province"
sPE_Items(30,0) = "city"

sPE_Items(0,1) = "powereasy"
sPE_Items(1,1) = ""
sPE_Items(2,1) = ""
sPE_Items(3,1) = "0"
sPE_Items(4,1) = "操作已成功完成!"
sPE_Items(5,1) = ""
sPE_Items(6,1) = ""
sPE_Items(7,1) = ""
sPE_Items(8,1) = ""
sPE_Items(9,1) = ""
sPE_Items(10,1) = ""
sPE_Items(11,1) = ""
sPE_Items(12,1) = ""
sPE_Items(13,1) = ""
sPE_Items(14,1) = ""
sPE_Items(15,1) = ""
sPE_Items(16,1) = ""
sPE_Items(17,1) = ""
sPE_Items(18,1) = ""
sPE_Items(19,1) = ""
sPE_Items(20,1) = ""
sPE_Items(21,1) = ""
sPE_Items(22,1) = ""
sPE_Items(23,1) = ""
sPE_Items(24,1) = ""
sPE_Items(25,1) = ""
sPE_Items(26,1) = ""
sPE_Items(27,1) = ""
sPE_Items(28,1) = ""
sPE_Items(29,1) = ""
sPE_Items(30,1) = ""

'定义与数组对应的常量,便于在编写程序时使用
Const conAppid = 0
Const conAction = 1
Const conSyskey = 2
Const conStatus = 3
Const conMessage = 4
Const conUsername = 5
Const conPassword = 6
Const conEmail = 7
Const conQuestion = 8
Const conAnswer = 9
Const conSavecookie = 10
Const conTruename = 11
Const conGender = 12
Const conBirthday = 13
Const conQQ = 14
Const conMsn = 15
Const conMobile = 16
Const conTelephone = 17
Const conAddress = 18
Const conZipcode = 19
Const conHomepage = 20
Const conUserip = 21
Const conJointime = 22
Const conExperience = 23
Const conTicket = 24
Const conValuation = 25
Const conBalance = 26
Const conPosts = 27
Const conUserstatus = 28
Const conProvince = 29
Const conCity = 30

'**************************************************
'函数名:prepareXML(vIsQuest)
'作  用:生成要发送的数据
'参  数:vIsQuest True=发送请求;False=响应请求
'**************************************************
Sub prepareXML(vIsQuest)
    'On Error Resume Next
    Dim TemplateFile,intIndex
    If vIsQuest Then
        TemplateFile = Server.MapPath(InstallDir & "API/Request.xml")
    Else
        TemplateFile = Server.MapPath(InstallDir & "API/Response.xml")
    End If
    If not IsObject(sMyXmlDoc) Then createXmlDom
    sMyXmlDoc.Async = False
    sMyXmlDoc.Load(TemplateFile)
    If Err Then
        Err.Clear
        FoundErr = True
        ErrMsg = "加载XML模版文件出错!"
        Exit Sub
    Else
        For intIndex = 0 to Ubound(sPE_Items,1)
            If vIsQuest Then
                '如果是请求包,不处理响应包专用元素
                If intIndex <> conStatus And intIndex <> conMessage Then
                    setNodeText sPE_Items(intIndex,0),sPE_Items(intIndex,1)
                End If
            Else
                '如果是响应包,不处理请求包专用元素
                If intIndex <> conAction And intIndex <> conSyskey And intIndex <> conUsername Then
                    setNodeText sPE_Items(intIndex,0),sPE_Items(intIndex,1)
                End If
            End If
        Next
    End If
End Sub

'**************************************************
'函数名:prepareData(vIsQuest)
'作  用:从XML中获取用户信息
'参  数:vIsQuest True=请求格式;False=响应格式
'**************************************************
Sub prepareData(vIsQuest)
    'On Error Resume Next
    Dim intIndex
    For intIndex = 0 to Ubound(sPE_Items,1)
        If vIsQuest Then
            '如果是请求包,不处理响应包专用元素
            If intIndex <> conStatus Or intIndex <> conMessage Then
                sPE_Items(intIndex,1) = getNodeText(sPE_Items(intIndex,0))
            End If
        Else
            '如果是响应包,不处理请求包专用元素
            If intIndex <> conSyskey Or intIndex <> conUsername Or intIndex <> conPassword Then
                sPE_Items(intIndex,1) = getNodeText(sPE_Items(intIndex,0))
            End If
        End If
    Next
End Sub

'**************************************************
'函数名:getNodeText
'作  用:获取XML文件中指定节点的文本
'参  数:strElementName   ----节点名称
'返回值:解析出来的文本值,
'**************************************************
Function getNodeText(strElementName)
    If IsNull(strElementName) Or IsEmpty(strElementName) Or strElementName = "" Then Exit Function
    On Error Resume Next
    getNodeText = sMyXmlDoc.getElementsByTagName(strElementName).item(0).text
    If Err Then
        getNodeText = ""
        Err.Clear
    End If
End Function

'**************************************************
'函数名:setNodeText
'作  用:设置XML文件中指定节点的文本
'参  数:strNodeName   ----节点名称
'    strNodeText   ----要设置的文本
'返回值:0 = 设置成功; 否则返回Err.Description
'**************************************************
Function setNodeText(strNodeName, strNodeText)
    If IsNull(strNodeText) Or IsEmpty(strNodeText) or strNodeText = "" Then Exit Function
    If IsNull(strNodeName) Or IsEmpty(strNodeName) or strNodeName = "" Then Exit Function
    
    sMyXmlDoc.getElementsByTagName(strNodeName).Item(0).text = strNodeText
End Function

'**************************************************
'函数名:IsNode
'作  用:检查一个Node是否存在且文本不为空
'参  数:strNodeName   ----节点名称
'返回值:True or False
'**************************************************
Function IsNode(strNodeName)
    IsNode = False
    On Error Resume Next
    Dim strTemp
    strTemp = sMyXmlDoc.getElementsByTagName(strNodeName).item(0).text
    If Err Or IsNull(strTemp) Or strTemp = "" Then
        IsNode = False
    Else
        IsNode = True
    End If
End Function

'**************************************************
'函数名:createXmlDom
'作  用:创建尽可能高版本的MSXML对象
'参  数:无
'返回值:True - 创建sMyXmlDoc成功
'    False - 服务器不支持MSXML对象
'**************************************************
Function createXmlDom()
    On Error Resume Next
    Set sMyXmlDoc = Server.CreateObject("MSXML2.FreeThreadedDOMDocument")
    If Err Then
        Err.Clear
        createXmlDom = False
        FoundErr = True
        ErrMsg = "服务器不支持MSXML2.FreeThreadedDOMDocument对象"
    Else
        createXmlDom = True
    End If
End function
'**************************************************
'函数名:createXmlHTTP
'作  用:创建尽可能高版本的ServerXMLHTTP对象
'参  数:无
'返回值:True - 创建sMyXmlDoc成功
'    False - 服务器不支持ServerXMLHTTP对象
'**************************************************
Private Function createXmlHttp()
    On Error Resume Next
    Set sMyXmlHTTP = Server.CreateObject("MSXML2.ServerXMLHTTP")
    If Err Then
        createXmlHttp = False
        FoundErr = True
        ErrMsg = "服务器不支持ServerXMLHTTP对象"
    Else
        createXmlHttp = True
    End If
End Function

'**************************************************
'过程名:SendPost
'作  用:处理远程系统的通讯,用异步方式发送请求
'参  数:无
'**************************************************
Sub SendPost()
    If createXmlHttp Then
        sPE_Items(conUsername,1) = getNodeText(sPE_Items(conUsername,0))
        sPE_Items(conSyskey,1) = MD5(sPE_Items(conUsername,1) & API_Key,16)
        setNodeText sPE_Items(conSyskey,0), sPE_Items(conSyskey,1)
        sMyXmlHTTP.setTimeouts API_Timeout,API_Timeout,API_Timeout*6,API_Timeout*6
        Dim intIndex
        For intIndex = 0 to Ubound(arrAPIUrls)
            sMyXmlHttp.open "POST", arrUrlsSp2(intIndex), False
            sMyXmlHttp.setRequestHeader "Content-Type", "text/xml; charset=gb2312"
            sMyXmlHttp.send sMyXmlDoc
            If sMyXmlHTTP.readyState = 4 and sMyXmlHTTP.status = 200 Then
                Dim objRecXml
                set objRecXml = Server.CreateObject("Microsoft.XMLDOM")
                objRecXml.Async = False
                objRecXml.Load(sMyXmlHTTP.ResponseXML)
                If Err Then
                    FoundErr = True
                    ErrMsg = "用户服务目前不可用。[APIError-HTTP1-" & intIndex & "]"
                    Err.Clear
                ElseIf objRecXml.parseError.errorCode <> 0 Then
                    FoundErr = True
                    ErrMsg = "用户服务目前不可用。[APIError-XmlParse-" & intIndex & "]"
                    Err.Clear
                Else
                    If objRecXml.documentElement.selectSingleNode("//status").text <> "0" Then
                        FoundErr = True
                        ErrMsg = objRecXml.documentElement.selectSingleNode("//message").text & " [APIError-API-" & intIndex & "]"
                    End If
                End If
            ElseIf sMyXmlHttp.readyState = 4 and sMyXmlHttp.status <> 200 Then
                FoundErr = True
                'ErrMsg = "用户服务目前不可用! [APIError-HTTP2-" & intIndex & "]"
                ErrMsg = BytesToBstr(sMyXmlHttp.ResponseBody, "gb2312")
            End If
            If FoundErr Then
                If intIndex > 0 Then
                    RollbackUser intIndex
                End If
                Exit For
            End If
        Next
    Else
        FoundErr = True
        ErrMsg = "用户服务目前不可用! [APIError-HTTP-Runtime]"
    End If
End Sub

Sub RollbackUser(startIndex)
    startIndex = startIndex - 1
    Do While startIndex >= 0
        setNodeText "action", "delete"
        sMyXmlHttp.open "POST", arrUrlsSP2(startIndex), True
        sMyXmlHttp.setRequestHeader "Content-Type", "text/xml; charset=gb2312"
        sMyXmlHttp.send sMyXmlDoc
        startIndex = startIndex - 1
    Loop
End Sub

Sub WriteErrXml()
    Response.Clear
    Response.ContentType = "text/xml"
    Response.Charset = "gb2312"
    Response.Expires = 0 
    Response.Expiresabsolute = Now() - 1 
    Response.AddHeader "pragma","no-cache" 
    Response.AddHeader "cache-control","private" 
    Response.CacheControl = "no-cache"
    Response.Write "<?xml version=""1.0"" encoding=""gb2312""?>" & vbNewLine
    Response.Write "<root><appid>powereasy</appid><status>1</status><body><message>" & ErrMsg & "</message></body></root>"
    Response.End
End Sub
Sub WriteXml()
    Response.Clear
    Response.ContentType = "text/xml"
    Response.Charset = "gb2312"
    Response.Expires = 0 
    Response.Expiresabsolute = Now() - 1 
    Response.AddHeader "pragma","no-cache" 
    Response.AddHeader "cache-control","private" 
    Response.CacheControl = "no-cache"
    Response.Write "<?xml version=""1.0"" encoding=""gb2312""?>" & vbNewLine
    Response.Write sMyXmlDoc.documentElement.xml
    Response.End
End Sub

Function exchangeGender(iSex)
    If IsNull(iSex) Or iSex = "" Or Not IsNumeric(iSex) Then
        exchangeGender = 2
        Exit Function
    End If
    If iSex = "1" Then
        iSex = 0
    ElseIf iSex = "0" Then
        iSex = 1
    Else
        iSex = 2
    End If
End Function

Public Function AnsiToUnicode(ByVal str)
    Dim i, j, c, i1, i2, u, fs, f, p
    AnsiToUnicode = ""
    p = ""
    For i = 1 To Len(str)
        c = Mid(str, i, 1)
        j = AscW(c)
        If j < 0 Then
            j = j + 65536
        End If
        If j >= 0 And j <= 128 Then
            If p = "c" Then
                AnsiToUnicode = " " & AnsiToUnicode
                p = "e"
            End If
            AnsiToUnicode = AnsiToUnicode & c
        Else
            If p = "e" Then
                AnsiToUnicode = AnsiToUnicode & " "
                p = "c"
            End If
            AnsiToUnicode = AnsiToUnicode & ("&#" & j & ";")
        End If
    Next
End Function

Private Function BytesToBstr(Body, Cset)
    Dim Objstream
    Set Objstream = Server.CreateObject("adodb.stream")
    Objstream.Type = 1
    Objstream.Mode = 3
    Objstream.Open
    Objstream.Write Body
    Objstream.Position = 0
    Objstream.Type = 2
    Objstream.Charset = Cset
    If Err.Number <> 0 Then
        Err.Clear
        Objstream.Close
        Set Objstream = Nothing
        BytesToBstr = "$False$"
        Exit Function
    End If
    BytesToBstr = Objstream.ReadText
    Objstream.Close
    Set Objstream = Nothing
End Function
%>

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -