陆金所新安e项目短信和语音通知
前几天股市大跌,趋势策略跟踪中创100指数的部分到了止损位置,退出了约300万资金,想投到安e产品,但是发现陆金所最近非常变态,二手安e项目手机上一天只能抢2-3个,然后就要求语音验证码,接个电话听验证码肯定就别想抢到了。想编个外挂在电脑上抢二手项目,但是发现技术不行,速度太慢了抢不过别的外挂。
干脆就买新项目吧,期限36个月,收益率去掉信息费7.56也还可以。新项目相对好买一些,出的话都是一大堆一起出,但是出现的时间不确定,一天可能就出一批或者根本不出,出了就几分钟抢光了。
想了个解决办法,用autoit编了个小程序,电脑打开网贷新项目页面不停刷新查看,发现新项目出来后语音提示,同时发邮件到移动139邮箱,设置邮箱收信后自动发短信到手机提醒。这样不管人在不在家都能及时去抢项目。
主程序:循环刷新网页,取色查看新项目是不是出现,出现的话按钮是某种红色。(焦点位置需要自己设置。)
While 1
Sleep(5000)
Send("{F5}")
Sleep(3000)
$var = PixelGetColor( 831 ,408 )
if $var<>15987699 Then
Run("D:\1.bat")
Run("D:\陆金所抢新项目短信通知.exe")
EndIf
WEnd
其中D:\1.bat为语音提示,一行代码打开一个vbs:
Dim userInput
userInput ="陆金所抢抢抢"
Set Sapi = Wscript.CreateObject("SAPI.SpVoice")
Sapi.speak userInput
“陆金所抢新项目短信通知.exe”为编译过的au3文件,负责发邮件,代码如下,xxxx部分需要填写:
#Include<file.au3>
$SmtpServer = "smtp.139.com"
$FromName = ""
$FromAddress = "xxxx@139.com"
$ToAddress = "xxxx@139.com"
$Subject = "xxxx"
$Body = ""
$AttachFiles = ""
$CcAddress = ""
$BccAddress = ""
$Importance = "Normal"
$Username = "xxxx"
$Password = "xxxx"
$IPPort = 25
$ssl = 0
Global $oMyRet[2]
Global $oMyError = ObjEvent("AutoIt.Error", "MyErrFunc")
$rc = _INetSmtpMailCom($SmtpServer, $FromName, $FromAddress, $ToAddress, $Subject, $Body, $AttachFiles, $CcAddress, $BccAddress, $Importance, $Username, $Password, $IPPort, $ssl)
If @error Then
MsgBox(0, "Error sending message", "Error code:" & @error & " Description:" & $rc)
EndIf
Func _INetSmtpMailCom($s_SmtpServer, $s_FromName, $s_FromAddress, $s_ToAddress, $s_Subject = "", $as_Body = "", $s_AttachFiles = "", $s_CcAddress = "", $s_BccAddress = "", $s_Importance="Normal", $s_Username = "", $s_Password = "", $IPPort = 25, $ssl = 0)
Local $objEmail = ObjCreate("CDO.Message")
$objEmail.From = '"' & $s_FromName & '" <' & $s_FromAddress & '>'
$objEmail.To = $s_ToAddress
Local $i_Error = 0
Local $i_Error_desciption = ""
If $s_CcAddress <> "" Then $objEmail.Cc = $s_CcAddress
If $s_BccAddress <> "" Then $objEmail.Bcc = $s_BccAddress
$objEmail.Subject = $s_Subject
If StringInStr($as_Body, "<") And StringInStr($as_Body, ">") Then
$objEmail.HTMLBody = $as_Body
Else
$objEmail.Textbody = $as_Body & @CRLF
EndIf
If $s_AttachFiles <> "" Then
Local $S_Files2Attach = StringSplit($s_AttachFiles, ";")
For $x = 1 To $S_Files2Attach[0]
$S_Files2Attach[$x] = _PathFull($S_Files2Attach[$x])
ConsoleWrite('@@ Debug(62) : $S_Files2Attach = ' & $S_Files2Attach & @LF & '>Error code: ' & @error & @LF) ;### Debug Console
If FileExists($S_Files2Attach[$x]) Then
$objEmail.AddAttachment ($S_Files2Attach[$x])
Else
ConsoleWrite('!> File not found to attach: ' & $S_Files2Attach[$x] & @LF)
SetError(1)
Return 0
EndIf
Next
EndIf
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/sendusing") = 2
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/smtpserver") = $s_SmtpServer
If Number($IPPort) = 0 then $IPPort = 25
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/smtpserverport") = $IPPort
If $s_Username <> "" Then
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/smtpauthenticate") = 1
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/sendusername") = $s_Username
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/sendpassword") = $s_Password
EndIf
If $ssl Then
$objEmail.Configuration.Fields.Item ("https://schemas.microsoft.com/cdo/configuration/smtpusessl") = True
EndIf
$objEmail.Configuration.Fields.Update
Switch $s_Importance
Case "High"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "High"
Case "Normal"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "Normal"
Case "Low"
$objEmail.Fields.Item ("urn:schemas:mailheader:Importance") = "Low"
EndSwitch
$objEmail.Fields.Update
$objEmail.Send
If @error Then
SetError(2)
Return $oMyRet[1]
EndIf
$objEmail=""
EndFunc
Func MyErrFunc()
$HexNumber = Hex($oMyError.number, 8)
$oMyRet[0] = $HexNumber
$oMyRet[1] = StringStripWS($oMyError.description, 3)
ConsoleWrite("### COM Error ! Number: " & $HexNumber & " ScriptLine: " & $oMyError.scriptline & " Description:" & $oMyRet[1] & @LF)
SetError(1)
Return
EndFunc