118 lines
2.9 KiB
Go
118 lines
2.9 KiB
Go
package BitSrun
|
|
|
|
import (
|
|
"encoding/json"
|
|
"errors"
|
|
"github.com/Mmx233/BitSrunLoginGo/util"
|
|
"github.com/Mmx233/BitSrunLoginGo/v1/transfer"
|
|
"github.com/Mmx233/tool"
|
|
"time"
|
|
)
|
|
|
|
func Login(c *srunTransfer.Login) error {
|
|
util.Log.DebugMode = c.Debug
|
|
util.Log.WriteFile = c.WriteLog
|
|
util.Log.OutPut = c.OutPut
|
|
|
|
G := util.GenerateLoginInfo(c.Https, c.LoginInfo.Form, c.LoginInfo.Meta)
|
|
if c.CheckNet {
|
|
util.Log.Info("Step0: 检查状态…")
|
|
if util.Checker.NetOk(c.Transport) {
|
|
util.Log.Info("网络 ok")
|
|
return nil
|
|
}
|
|
}
|
|
|
|
util.Log.Info("Step1: 正在获取客户端ip")
|
|
{
|
|
util.Log.Debug("GET ", G.UrlLoginPage)
|
|
if _, body, e := tool.HTTP.GetString(&tool.GetRequest{
|
|
Url: G.UrlLoginPage,
|
|
Redirect: true,
|
|
Transport: c.Transport,
|
|
}); e != nil {
|
|
return e
|
|
} else if G.Ip, e = util.GetIp(body); e != nil {
|
|
return e
|
|
}
|
|
}
|
|
|
|
util.Log.Info("Step2: 正在获取Token")
|
|
{
|
|
util.Log.Debug("GET ", G.UrlGetChallengeApi)
|
|
if _, data, e := tool.HTTP.GetString(&tool.GetRequest{
|
|
Url: G.UrlGetChallengeApi,
|
|
Query: map[string]interface{}{
|
|
"callback": "jsonp1583251661367",
|
|
"username": G.Form.UserName,
|
|
"ip": G.Ip,
|
|
},
|
|
Redirect: true,
|
|
Transport: c.Transport,
|
|
}); e != nil {
|
|
return e
|
|
} else if G.Token, e = util.GetToken(data); e != nil {
|
|
return e
|
|
}
|
|
}
|
|
|
|
util.Log.Info("Step3: 执行登录…")
|
|
{
|
|
info, e := json.Marshal(map[string]string{
|
|
"username": G.Form.UserName,
|
|
"password": G.Form.PassWord,
|
|
"ip": G.Ip,
|
|
"acid": G.Meta.Acid,
|
|
"enc_ver": G.Meta.Enc,
|
|
})
|
|
if e != nil {
|
|
return e
|
|
}
|
|
G.EncryptedInfo = "{SRBX1}" + util.Base64(util.XEncode(string(info), G.Token))
|
|
G.Md5 = util.Md5(G.Token)
|
|
G.EncryptedMd5 = "{MD5}" + G.Md5
|
|
|
|
var chkstr = G.Token + G.Form.UserName + G.Token + G.Md5
|
|
chkstr += G.Token + G.Meta.Acid + G.Token + G.Ip
|
|
chkstr += G.Token + G.Meta.N + G.Token + G.Meta.Type
|
|
chkstr += G.Token + G.EncryptedInfo
|
|
G.EncryptedChkstr = util.Sha1(chkstr)
|
|
|
|
util.Log.Debug("GET ", G.UrlLoginApi)
|
|
if _, res, e := tool.HTTP.GetString(&tool.GetRequest{
|
|
Url: G.UrlLoginApi,
|
|
Query: map[string]interface{}{
|
|
"callback": "jQuery112401157665",
|
|
"action": "login",
|
|
"username": G.Form.UserName,
|
|
"password": G.EncryptedMd5,
|
|
"ac_id": G.Meta.Acid,
|
|
"ip": G.Ip,
|
|
"info": G.EncryptedInfo,
|
|
"chksum": G.EncryptedChkstr,
|
|
"n": G.Meta.N,
|
|
"type": G.Meta.Type,
|
|
"os": "Windows 10",
|
|
"name": "windows",
|
|
"double_stack": 0,
|
|
"_": time.Now().UnixNano(),
|
|
},
|
|
Redirect: true,
|
|
Transport: c.Transport,
|
|
}); e != nil {
|
|
return e
|
|
} else if G.LoginResult, e = util.GetResult(res); e != nil {
|
|
return e
|
|
} else {
|
|
util.Log.Info("登录结果: " + G.LoginResult)
|
|
util.Log.Debug(res)
|
|
}
|
|
|
|
if G.LoginResult != "ok" {
|
|
return errors.New(G.LoginResult)
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|