BBS注册机(vb script, telnet, sterm)

#include "lib.vbs"

Const nTimeout = 3  'in second

Const NewSucceed = 0
Const NewFaild = 1
Const LimitedNew = 2
Const IDExist = 3

Const NickLen = 38
Const IDLenMin = 2
Const IDLenMax = 12

WantedIdFile = "id_wanted.txt"
DoneIdFile = "id_done.txt"

'Information used fro registration
Const strPassWord = "!@#$%^"
Const strNickName = "GRE Word List"
Const strRealName = "我爱背单词"
Const strDepartment = "浙江大学计算机学院"
Const strAddress = "浙江大学玉泉校区30舍"
Const strGrade = "2001"
Const strPhone = "87931624"

'Option Explicit
Main
MsgBox ("Script End")


Sub Main()

 'Dim bConnect, nTime, nScreenHeight, strScreenLine, nDelay
 
 Dim fsoWanted, fsoDone, tsWanted, tsDone
 Dim strLine, strID, strNick
 Dim pos

    Dim NewRegistResult

 Set fsoWanted = CreateObject("Scripting.FileSystemObject")
 Set fsoDone = CreateObject("Scripting.FileSystemObject")
 Set tsWanted = fsoWanted.OpenTextFile(WantedIdFile, ForReading)
 Set tsDone = fsoDone.OpenTextFile(DoneIdFile, ForAppending, True)

 Do While (Not tsWanted.AtEndOfStream)
        strLine = tsWanted.ReadLine
        pos = InStr(strLine, " ")
        strID = Left(strLine, pos-1)
        strNick = Mid(strLine, pos+1, NickLen)
        strID = TrimAll(strID)

        If (strNick = "") Then
            strNick = strNickName
        End If

        If (Len(strID) >= IDLenMin And Len(strID) <= IDLenMax) Then    'lenght of ID must in [2, 12]
            ReconnectHost()
            NewRegistResult = NewAndRegistrID(strID, strNick)
            If (NewRegistResult = NewSucceed) Then
                tsDone.WriteLine(strID)                     '记录注册成功的ID
            ElseIf (NewRegistResult = IDExist) Then
                tsDone.WriteLine("# "+strID+" "+strNick)    '记录冲突的ID
            ElseIf (NewRegistResult = NewFaild) Then
                tsDone.WriteLine("@ "+strID+" "+strNick)    '记录注册失败的ID
            ElseIf (NewRegistResult = LimitedNew) Then
                tsDone.WriteLine("$已经到达每日注册上限")   '不能再注册了
                STermScript.Disconnect()
                Exit Do
            End If
            STermScript.Disconnect()
        Else
            tsDone.WriteLine("& "+strID+" "+strNick)    '记录长度出错的ID
        End If

        StermScript.Delay(500)    '延时
    Loop
 

 tsWanted.Close
 tsDone.Close
 
End Sub


'************************************************************
'* Function: NewAndRegistrID(ByRef strIDWanted)              *
'* Return Value:                                            *
'* 新建一个帐号                                             *
'************************************************************
Function NewAndRegistrID(ByRef strIDWanted, ByRef strNick)

'Return Value:
'Const NewSucceed = 0
'Const NewFaild = 1
'Const LimitedNew = 2
'Const IDExist = 3

    Dim nScrH, strLine, strLeft

    '新建一个帐号
 If (Not WaitUntil("请输入帐号", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData("new" + Chr(13)) '发送new
 End If

    '您今天不能再申请新帐号了
    If (InStr(STermScript.GetBuffer(STermScript.GetCursorY()), "不能再申请") > 0) Then
        NewAndRegistrID = LimitedNew
        Exit Function
    End If

 If (Not WaitUntil("请输入帐号名称", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData(strIDWanted + Chr(13)) '输入要新建的ID
 End If


    StermScript.Delay(500) '延时,等待ID冲突判断

    '此帐号已经有人使用
    If (InStr(STermScript.GetBuffer(STermScript.GetCursorY()-1), "已经") > 0) Then
        NewAndRegistrID = IDExist
        Exit Function
    End If


 If (Not WaitUntil("请设定您的密码", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData(strPassWord + Chr(13)) '输入密码
 End If

 If (Not WaitUntil("请再输入一次你的密码", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData(strPassWord + Chr(13)) '再次输入密码
 End If


 '跳过欢迎屏幕
    Do
        STermScript.SendData(goDown)
        'StermScript.Delay(100)
    Loop Until (InStr(STermScript.GetBuffer(STermScript.GetCursorY()), "请输入您的昵称") > 0) '调到输入昵称的那行

    StermScript.SendData(strNick + Chr(13)) '输入昵称
    StermScript.SendData(strRealName + Chr(13)) '输入真实姓名


 If (Not WaitUntil("您确定要填写注册单吗", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData("Y" + Chr(13)) '再次输入密码
 End If

    StermScript.SendData(strRealName + Chr(13))     '真实姓名: 马甲
    StermScript.SendData(strDepartment + Chr(13))   '学校院系: 浙江大学计算机学院
    StermScript.SendData(strAddress + Chr(13))  '详细住址: 浙江大学玉泉校区30舍
    StermScript.SendData(strGrade + Chr(13))    '年级(如1999): 2001
    StermScript.SendData(strPhone + Chr(13))    '联络电话: 87931624

    '以上资料是否正确, 按 Q 放弃注册 (Y/N/Quit)? [N]:
 If (Not WaitUntil("以上资料是否正确", nTimeout)) Then
  NewAndRegistrID = NewFaild
  Exit Function
 Else
  STermScript.SendData("Y" + Chr(13)) '再次输入密码
 End If

 NewAndRegistrID = NewSucceed
 
End Function

vbs 批量修改文件,bat 批处理文件调用执行vbs,并在cmd窗口打印返回值(vbs运行结果) 使用vbs 脚本对工作目录下的字符串进行替换并统计被修改的文件数主调的批处理方法将捕捉该vbs脚本运行后的结果并打印在cmd窗口。 示例代码(t.vbs)如下: Set fso=Wscript.CreateObject("Scripting.FileSystemObject") flrName="D:\Workspace\src\" 'dir that you need deal with count=0 'get the count of modified files function Traversal(dir) set flr=fso.getfolder(dir) set fs=flr.files findstr1="[assembly: SecurityTransparent]" 'find string that need to be replaced findstr2=replace(findstr1," ","") 'becasuse there isspace char in findstr,so add this findstr2 replaceStr="[assembly: AllowPartiallyTrustedCallers()]" 'destination stringin replace for each f in fs if lcase(f.name)="assemblyinfo.cs" then set findf=fso.opentextfile(f) do while findf.atendofstream=false d=f.datelastmodified 'get modified datetime of current file alltext=findf.readall if(InStr(alltext,findstr1)> 0 ) then s=replace(alltext,findstr1, replaceStr) count=count+1 findf.close() 'If no findstr2, delete the following elseif block elseif(InStr(alltext,findstr2) > 0) then s=replace(alltext,findstr2, replaceStr) count=count+1 findf.close() else findf.close() exit do end if set r=fso.opentextfile(f, 2, true) r.write s d2=f.datelastmodified if d2>=d then exit do loop end if next set fs=flr.subfolders for each f in fs Traversal(f.path) next end function Traversal(flrName) 'msgbox ("Done! "& count &" files were modified successfully.") wscript.echo "Done! "& count & " files were modified successfully." 'value popup by"wscript.echo" can be received by .bat easily Wscript.quit count 'this variable "count" in order to get a return value by%ErrorLevel% 上面的操作只执行了处理文件的步骤 如果不需要提取运行结果,在 批处理 或主调vbs脚本里直接 运行该vbs文件就行了。 如果在bat 里调用该vbs脚本,并希望打印出提示信息 可以用下面的两种方法来实现: 1,在bat中加入如下代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值