(转)利用ASP远程注册DLL的方法

<!--利用ASP远程注册DLL的方法-->

<% Response.Buffer = True %>
<% Server.ScriptTimeout = 500
Dim frmFolderPath, frmFilePath

frmFolderPath = Request.Form("frmFolderPath")
frmFilePath   = Request.Form("frmDllPath")
frmMethod     = Request.Form("frmMethod")
btnREG        = Request.Form("btnREG")
%>

<HTML>
<HEAD>
<TITLE>Regsvr32.asp</TITLE>
<STYLE TYPE="TEXT/CSS">
.Legend{FONT-FAMILY:veranda;FONT-SIZE:14px;FONT-WEIGHT:bold;COLOR:blue}
.FS{FONT-FAMILY:veranda;FONT-SIZE:12px;BORDER:4px green;MARGIN-LEFT:2px;MARGIN-RIGHT:2px}
TD{MARGIN-LEFT:6px;MARGIN-RIGHT:6px;PADDING-LEFT:12px;PADDING-RIGHT:12px}
</STYLE>
</HEAD>

<BODY>
<FORM NAME="regForm" METHOD="POST">
<TABLE BORDER=0 CELLSPACING=6 CELLPADDING=6 MARGINWIDTH=6>
  <TR>
    <TD VALIGN=TOP><FIELDSET ID=FS1 NAME=FS1 CLASS=FS>
      <LEGEND CLASS=Legend>Regsvr Functions</LEGEND>
      Insert Path to DLL Directory<BR>
      <INPUT TYPE=TEXT NAME=frmFolderPath VALUE="<%=frmFolderPath%>"><BR>
      <INPUT TYPE=SUBMIT NAME=btnFileList VALUE="Build File List"><BR>
<%IF Request.Form("btnFileList") <> "" OR btnREG <> "" Then
    Set RegisterFiles = New clsRegister
    RegisterFiles.EchoB("<B>Select File</B>")
    Call RegisterFiles.init(frmFolderPath)
    RegisterFiles.EchoB("<BR><INPUT TYPE=SUBMIT NAME=btnREG VALUE=" & Chr(34) & "REG/UNREG" & Chr(34) & ">")
    IF Request.Form("btnREG") <> "" Then
      Call RegisterFiles.Register(frmFilePath, frmMethod)
    End IF
    Set RegisterFiles = Nothing
  End IF
%>
      </FIELDSET>
    </TD>
  </TR>
</TABLE>
</FORM>
</BODY>
</HTML>

<%
Class clsRegister
  Private m_oFS
  Public Property Let oFS(objOFS)
    m_oFS = objOFS
  End Property
  Public Property Get oFS()
    Set oFS = Server.CreateObject("Scripting.FileSystemObject")
  End Property
  Sub init(strRoot) 'Root to Search (c:, d:, e:)
    Dim oDrive, oRootDir
    IF oFS.FolderExists(strRoot) Then
      IF Len(strRoot) < 3 Then 'Must Be a Drive
        Set oDrive = oFS.GetDrive(strRoot)
        Set oRootDir = oDrive.RootFolder
      Else
        Set oRootDir = oFS.GetFolder(strRoot)
      End IF
    Else
      EchoB("<B>Folder ( " & strRoot & " ) Not Found.")
      Exit Sub
    End IF
    setRoot = oRootDir
    Echo("<SELECT NAME=" & Chr(34) & "frmDllPath" & Chr(34) & ">")
    Call getAllDlls(oRootDir)
    EchoB("</SELECT>")
    BuildOptions
  End Sub
  Sub getAllDlls(oParentFolder)
    Dim oSubFolders, oFile, oFiles
    Set oSubFolders = oParentFolder.SubFolders
    Set opFiles = oParentFolder.Files
    For Each oFile in opFiles
      IF Right(lCase(oFile.Name),4)=".dll" OR Right(lCase(oFile.Name),4) =".ocx" Then
        Echo("<OPTION VALUE=" & Chr(34) & oFile.Path & Chr(34) & ">" & oFile.Name & "</Option>")
      End IF
    Next
    On Error Resume Next
    For Each oFolder In oSubFolders 'Iterate All Folders in Drive
      Set oFiles = oFolder.Files
      For Each oFile in oFiles
        IF Right(lCase(oFile.Name),4) = ".dll" OR Right(lCase(oFile.Name),4) = ".ocx" Then
          Echo("<OPTION VALUE=" & Chr(34) & oFile.Path & Chr(34) & ">" & oFile.Name & "</Option>")
        End IF
      Next
      Call getAllDlls(oFolder)
    Next
    On Error GoTo 0
  End Sub
  Sub Register(strFilePath, regMethod)
    Dim theFile, strFile, oShell, exitcode
    Set theFile = oFS.GetFile(strFilePath)
    strFile = theFile.Path
    Set oShell = CreateObject ("WScript.Shell")
    IF regMethod = "REG" Then 'Register
      oShell.Run "c:/WINNT/system32/regsvr32.exe /s " & strFile, 0, False
      exitcode = oShell.Run("c:/WINNT/system32/regsvr32.exe /s " & strFile, 0, False)
      EchoB("regsvr32.exe exitcode = " & exitcode)
    Else 'unRegister
      oShell.Run "c:/WINNT/system32/regsvr32.exe /u/s " & strFile, 0, False
      exitcode = oShell.Run("c:/WINNT/system32/regsvr32.exe /u/s " & strFile, 0, False)
      EchoB("regsvr32.exe exitcode = " & exitcode)
    End IF
    Cleanup oShell
  End Sub
  Sub BuildOptions
    EchoB("Register: <INPUT TYPE=RADIO NAME=frmMethod VALUE=REG CHECKED>")
    EchoB("unRegister: <INPUT TYPE=RADIO NAME=frmMethod VALUE=UNREG>")
  End Sub
  Function Echo(str)
    Echo = Response.Write(str & vbCrLf)
  End Function
  Function EchoB(str)
    EchoB = Response.Write(str & "<BR>" & vbCrLf)
  End Function
  Sub Cleanup(obj)
    If isObject(obj) Then
      Set obj = Nothing
    End IF
  End Sub
  Sub Class_Terminate()
    Cleanup oFS
  End Sub
End Class
%>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值