mirror of
https://github.com/FlourishingWorld/hk4e.git
synced 2026-02-04 16:02:26 +08:00
机器人http登录
This commit is contained in:
@@ -190,7 +190,7 @@ func (k *KcpConnectManager) sendMsgHandle() {
|
|||||||
ServerMsg: serverMsg,
|
ServerMsg: serverMsg,
|
||||||
})
|
})
|
||||||
} else if protoMsg.CmdId == cmd.ClientReconnectNotify {
|
} else if protoMsg.CmdId == cmd.ClientReconnectNotify {
|
||||||
tokenResetRsp, err := httpclient.Post[controller.TokenResetRsp](
|
tokenResetRsp, err := httpclient.PostJson[controller.TokenResetRsp](
|
||||||
config.CONF.Hk4e.LoginSdkUrl+"/gate/token/reset?key=flswld",
|
config.CONF.Hk4e.LoginSdkUrl+"/gate/token/reset?key=flswld",
|
||||||
&controller.TokenResetReq{
|
&controller.TokenResetReq{
|
||||||
PlayerId: session.userId,
|
PlayerId: session.userId,
|
||||||
@@ -342,7 +342,7 @@ func (k *KcpConnectManager) getPlayerToken(req *proto.GetPlayerTokenReq, session
|
|||||||
EventMessage: uint32(kcp.EnetLoginUnfinished),
|
EventMessage: uint32(kcp.EnetLoginUnfinished),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
tokenVerifyRsp, err := httpclient.Post[controller.TokenVerifyRsp](
|
tokenVerifyRsp, err := httpclient.PostJson[controller.TokenVerifyRsp](
|
||||||
config.CONF.Hk4e.LoginSdkUrl+"/gate/token/verify?key=flswld",
|
config.CONF.Hk4e.LoginSdkUrl+"/gate/token/verify?key=flswld",
|
||||||
&controller.TokenVerifyReq{
|
&controller.TokenVerifyReq{
|
||||||
AccountId: req.AccountUid,
|
AccountId: req.AccountUid,
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import (
|
|||||||
"encoding/json"
|
"encoding/json"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -15,17 +16,17 @@ func init() {
|
|||||||
Transport: &http.Transport{
|
Transport: &http.Transport{
|
||||||
DisableKeepAlives: true,
|
DisableKeepAlives: true,
|
||||||
},
|
},
|
||||||
Timeout: time.Second * 60,
|
Timeout: time.Second * 10,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func Get[T any](url string, token string) (*T, error) {
|
func GetJson[T any](url string, authToken string) (*T, error) {
|
||||||
req, err := http.NewRequest("GET", url, nil)
|
req, err := http.NewRequest("GET", url, nil)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if token != "" {
|
if authToken != "" {
|
||||||
req.Header.Set("Authorization", "Bearer"+" "+token)
|
req.Header.Set("Authorization", "Bearer"+" "+authToken)
|
||||||
}
|
}
|
||||||
rsp, err := httpClient.Do(req)
|
rsp, err := httpClient.Do(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -44,7 +45,27 @@ func Get[T any](url string, token string) (*T, error) {
|
|||||||
return responseData, nil
|
return responseData, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func Post[T any](url string, body any, token string) (*T, error) {
|
func GetRaw(url string, authToken string) (string, error) {
|
||||||
|
req, err := http.NewRequest("GET", url, nil)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
if authToken != "" {
|
||||||
|
req.Header.Set("Authorization", "Bearer"+" "+authToken)
|
||||||
|
}
|
||||||
|
rsp, err := httpClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
data, err := io.ReadAll(rsp.Body)
|
||||||
|
_ = rsp.Body.Close()
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return string(data), nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func PostJson[T any](url string, body any, authToken string) (*T, error) {
|
||||||
reqData, err := json.Marshal(body)
|
reqData, err := json.Marshal(body)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@@ -54,8 +75,8 @@ func Post[T any](url string, body any, token string) (*T, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
req.Header.Set("Content-Type", "application/json")
|
req.Header.Set("Content-Type", "application/json")
|
||||||
if token != "" {
|
if authToken != "" {
|
||||||
req.Header.Set("Authorization", "Bearer"+" "+token)
|
req.Header.Set("Authorization", "Bearer"+" "+authToken)
|
||||||
}
|
}
|
||||||
rsp, err := httpClient.Do(req)
|
rsp, err := httpClient.Do(req)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@@ -73,3 +94,24 @@ func Post[T any](url string, body any, token string) (*T, error) {
|
|||||||
}
|
}
|
||||||
return responseData, nil
|
return responseData, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func PostRaw(url string, body string, authToken string) (string, error) {
|
||||||
|
req, err := http.NewRequest("POST", url, strings.NewReader(body))
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
req.Header.Set("Content-Type", "application/json")
|
||||||
|
if authToken != "" {
|
||||||
|
req.Header.Set("Authorization", "Bearer"+" "+authToken)
|
||||||
|
}
|
||||||
|
rsp, err := httpClient.Do(req)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
rspData, err := io.ReadAll(rsp.Body)
|
||||||
|
_ = rsp.Body.Close()
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
return string(rspData), nil
|
||||||
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
"os/signal"
|
"os/signal"
|
||||||
|
"strconv"
|
||||||
"syscall"
|
"syscall"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@@ -11,6 +12,7 @@ import (
|
|||||||
"hk4e/pkg/logger"
|
"hk4e/pkg/logger"
|
||||||
"hk4e/protocol/cmd"
|
"hk4e/protocol/cmd"
|
||||||
"hk4e/protocol/proto"
|
"hk4e/protocol/proto"
|
||||||
|
"hk4e/robot/login"
|
||||||
"hk4e/robot/net"
|
"hk4e/robot/net"
|
||||||
|
|
||||||
"github.com/FlourishingWorld/dpdk-go/engine"
|
"github.com/FlourishingWorld/dpdk-go/engine"
|
||||||
@@ -28,7 +30,16 @@ func main() {
|
|||||||
|
|
||||||
time.Sleep(time.Second * 30)
|
time.Sleep(time.Second * 30)
|
||||||
|
|
||||||
session := net.NewSession("192.168.199.233:22222", make([]byte, 4096))
|
dispatchInfo, err := login.GetDispatchInfo("https://hk4e.flswld.com", "?version=OSRELWin3.2.0")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
accountInfo, err := login.AccountLogin("https://hk4e.flswld.com", "flswld", "123456")
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
|
gateAddr := dispatchInfo.GateIp + strconv.Itoa(int(dispatchInfo.GatePort))
|
||||||
|
session := net.NewSession(gateAddr, dispatchInfo.DispatchKey, 30000)
|
||||||
go func() {
|
go func() {
|
||||||
protoMsg := <-session.RecvChan
|
protoMsg := <-session.RecvChan
|
||||||
logger.Debug("protoMsg: %v", protoMsg)
|
logger.Debug("protoMsg: %v", protoMsg)
|
||||||
@@ -42,9 +53,9 @@ func main() {
|
|||||||
SentMs: uint64(time.Now().UnixMilli()),
|
SentMs: uint64(time.Now().UnixMilli()),
|
||||||
},
|
},
|
||||||
PayloadMessage: &proto.GetPlayerTokenReq{
|
PayloadMessage: &proto.GetPlayerTokenReq{
|
||||||
AccountToken: "xxxxxx",
|
AccountToken: accountInfo.ComboToken,
|
||||||
AccountUid: "10001",
|
AccountUid: strconv.Itoa(int(accountInfo.AccountId)),
|
||||||
KeyId: 0,
|
KeyId: 5,
|
||||||
ClientRandKey: "",
|
ClientRandKey: "",
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|||||||
126
robot/login/http_login.go
Normal file
126
robot/login/http_login.go
Normal file
@@ -0,0 +1,126 @@
|
|||||||
|
package login
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/base64"
|
||||||
|
"encoding/json"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"hk4e/dispatch/api"
|
||||||
|
"hk4e/pkg/httpclient"
|
||||||
|
"hk4e/pkg/logger"
|
||||||
|
"hk4e/pkg/random"
|
||||||
|
"hk4e/protocol/proto"
|
||||||
|
|
||||||
|
"github.com/pkg/errors"
|
||||||
|
pb "google.golang.org/protobuf/proto"
|
||||||
|
)
|
||||||
|
|
||||||
|
type DispatchInfo struct {
|
||||||
|
GateIp string
|
||||||
|
GatePort uint32
|
||||||
|
DispatchKey []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetDispatchInfo(url string, clientParam string) (*DispatchInfo, error) {
|
||||||
|
logger.Info("http get url: %v", url+"/query_region_list"+clientParam)
|
||||||
|
regionListBase64, err := httpclient.GetRaw(url+"/query_region_list"+clientParam, "")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
regionListData, err := base64.StdEncoding.DecodeString(regionListBase64)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
queryRegionListHttpRsp := new(proto.QueryRegionListHttpRsp)
|
||||||
|
err = pb.Unmarshal(regionListData, queryRegionListHttpRsp)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
logger.Info("region list: %v", queryRegionListHttpRsp.RegionList)
|
||||||
|
if len(queryRegionListHttpRsp.RegionList) == 0 {
|
||||||
|
return nil, errors.New("no region found")
|
||||||
|
}
|
||||||
|
selectRegion := queryRegionListHttpRsp.RegionList[0]
|
||||||
|
logger.Info("select region: %v", selectRegion)
|
||||||
|
logger.Info("http get url: %v", selectRegion.DispatchUrl+clientParam)
|
||||||
|
regionCurrBase64, err := httpclient.GetRaw(selectRegion.DispatchUrl+clientParam, "")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
regionCurrData, err := base64.StdEncoding.DecodeString(regionCurrBase64)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
queryCurrRegionHttpRsp := new(proto.QueryCurrRegionHttpRsp)
|
||||||
|
err = pb.Unmarshal(regionCurrData, queryCurrRegionHttpRsp)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
regionInfo := queryCurrRegionHttpRsp.RegionInfo
|
||||||
|
if regionInfo == nil {
|
||||||
|
return nil, errors.New("region info is nil")
|
||||||
|
}
|
||||||
|
ec2b, err := random.LoadEc2bKey(regionInfo.SecretKey)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
dispatchInfo := &DispatchInfo{
|
||||||
|
GateIp: regionInfo.GateserverIp,
|
||||||
|
GatePort: regionInfo.GateserverPort,
|
||||||
|
DispatchKey: ec2b.XorKey(),
|
||||||
|
}
|
||||||
|
return dispatchInfo, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
type AccountInfo struct {
|
||||||
|
AccountId uint32
|
||||||
|
Token string
|
||||||
|
ComboToken string
|
||||||
|
}
|
||||||
|
|
||||||
|
func AccountLogin(url string, account string, password string) (*AccountInfo, error) {
|
||||||
|
loginAccountRequestJson := &api.LoginAccountRequestJson{
|
||||||
|
Account: account,
|
||||||
|
Password: password,
|
||||||
|
IsCrypto: true,
|
||||||
|
}
|
||||||
|
logger.Info("http post url: %v", url+"/hk4e_global/mdk/shield/api/login")
|
||||||
|
loginResult, err := httpclient.PostJson[api.LoginResult](url+"/hk4e_global/mdk/shield/api/login", loginAccountRequestJson, "")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if loginResult.Retcode != 0 {
|
||||||
|
logger.Error("login error msg: %v", loginResult.Message)
|
||||||
|
return nil, errors.New("login error")
|
||||||
|
}
|
||||||
|
accountId, err := strconv.Atoi(loginResult.Data.Account.Uid)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
loginTokenData := &api.LoginTokenData{
|
||||||
|
Uid: loginResult.Data.Account.Uid,
|
||||||
|
Token: loginResult.Data.Account.Token,
|
||||||
|
}
|
||||||
|
loginTokenDataJson, err := json.Marshal(loginTokenData)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
comboTokenReq := &api.ComboTokenReq{
|
||||||
|
Data: string(loginTokenDataJson),
|
||||||
|
}
|
||||||
|
logger.Info("http post url: %v", url+"/hk4e_global/combo/granter/login/v2/login")
|
||||||
|
comboTokenRsp, err := httpclient.PostJson[api.ComboTokenRsp](url+"/hk4e_global/combo/granter/login/v2/login", comboTokenReq, "")
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if comboTokenRsp.Retcode != 0 {
|
||||||
|
logger.Error("v2 login error msg: %v", comboTokenRsp.Message)
|
||||||
|
return nil, errors.New("v2 login error")
|
||||||
|
}
|
||||||
|
accountInfo := &AccountInfo{
|
||||||
|
AccountId: uint32(accountId),
|
||||||
|
Token: loginResult.Data.Account.Token,
|
||||||
|
ComboToken: comboTokenRsp.Data.ComboToken,
|
||||||
|
}
|
||||||
|
return accountInfo, nil
|
||||||
|
}
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
package net
|
package net
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"strconv"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
hk4egatenet "hk4e/gate/net"
|
hk4egatenet "hk4e/gate/net"
|
||||||
@@ -21,8 +22,8 @@ type Session struct {
|
|||||||
useMagicSeed bool
|
useMagicSeed bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewSession(gateAddr string, dispatchKey []byte) (r *Session) {
|
func NewSession(gateAddr string, dispatchKey []byte, localPort int) (r *Session) {
|
||||||
conn, err := kcp.DialWithOptions(gateAddr, "0.0.0.0:30000")
|
conn, err := kcp.DialWithOptions(gateAddr, "0.0.0.0:"+strconv.Itoa(localPort))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logger.Error("kcp client conn to server error: %v", err)
|
logger.Error("kcp client conn to server error: %v", err)
|
||||||
return
|
return
|
||||||
@@ -92,7 +93,7 @@ func (s *Session) sendHandle() {
|
|||||||
_ = conn.Close()
|
_ = conn.Close()
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
kcpMsg := hk4egatenet.ProtoEncode(protoMsg, nil, nil)
|
kcpMsg := hk4egatenet.ProtoEncode(protoMsg, cmd.NewCmdProtoMap(), nil)
|
||||||
if kcpMsg == nil {
|
if kcpMsg == nil {
|
||||||
logger.Error("decode kcp msg is nil, convId: %v", convId)
|
logger.Error("decode kcp msg is nil, convId: %v", convId)
|
||||||
continue
|
continue
|
||||||
|
|||||||
Reference in New Issue
Block a user