补充算法两个,使程序可用
This commit is contained in:
43
Util/XBase64.go
Normal file
43
Util/XBase64.go
Normal file
@@ -0,0 +1,43 @@
|
|||||||
|
package Util
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
func getbyte(a byte)int{
|
||||||
|
x := int(a)
|
||||||
|
if x > 255 {
|
||||||
|
fmt.Println("INVALID_CHARACTER_ERR: DOM Exception 5")
|
||||||
|
os.Exit(3)
|
||||||
|
}
|
||||||
|
return x
|
||||||
|
}
|
||||||
|
|
||||||
|
func Base64(s []byte)string{
|
||||||
|
const ALPHA = "LVoJPiCN2R8G90yg+hmFHuacZ1OWMnrsSTXkYpUq/3dlbfKwv6xztjI7DeBE45QA"
|
||||||
|
const PADCHAR = "="
|
||||||
|
i:=0
|
||||||
|
b10:=0
|
||||||
|
var x []byte
|
||||||
|
imax:=len(s)-len(s)%3
|
||||||
|
if len(s)==0{
|
||||||
|
return ""
|
||||||
|
}
|
||||||
|
for i:=0;i<imax;i+=3{
|
||||||
|
b10=(getbyte(s[i])<<16)|(getbyte(s[i+1]) << 8)|(getbyte(s[i+2]))
|
||||||
|
x=append(x,ALPHA[(b10>>18)])
|
||||||
|
x=append(x,ALPHA[((b10 >> 12) & 63)])
|
||||||
|
x=append(x,ALPHA[((b10 >> 6) & 63)])
|
||||||
|
x=append(x,ALPHA[(b10 & 63)])
|
||||||
|
}
|
||||||
|
i=imax
|
||||||
|
if len(s)-imax==1{
|
||||||
|
b10=getbyte(s[i])<<16
|
||||||
|
x=append(x,ALPHA[(b10 >> 18)],ALPHA[((b10 >> 12) & 63)],PADCHAR[0],PADCHAR[0])
|
||||||
|
}else if len(s)-imax ==2{
|
||||||
|
b10=(getbyte(s[i])<<16)|(getbyte(s[i+1])<<8)
|
||||||
|
x=append(x,ALPHA[(b10 >> 18)],ALPHA[((b10 >> 12) & 63)],ALPHA[((b10 >> 6) & 63)],PADCHAR[0])
|
||||||
|
}
|
||||||
|
return string(x)
|
||||||
|
}
|
||||||
@@ -4,16 +4,16 @@ import (
|
|||||||
"math"
|
"math"
|
||||||
)
|
)
|
||||||
|
|
||||||
func ordat(msg string, idx int) byte {
|
func ordat(msg string, idx int) uint32 {
|
||||||
if len(msg) > idx {
|
if len(msg) > idx {
|
||||||
return []byte(msg)[idx]
|
return uint32([]byte(msg)[idx])
|
||||||
}
|
}
|
||||||
return byte(0)
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
func sensCode(content string, key bool) []byte {
|
func sensCode(content string, key bool) []uint32 {
|
||||||
l := len(content)
|
l := len(content)
|
||||||
pwd := make([]byte, 0)
|
pwd := make([]uint32, 0)
|
||||||
for i := 0; i < l; i += 4 {
|
for i := 0; i < l; i += 4 {
|
||||||
pwd = append(
|
pwd = append(
|
||||||
pwd,
|
pwd,
|
||||||
@@ -21,28 +21,29 @@ func sensCode(content string, key bool) []byte {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
if key {
|
if key {
|
||||||
pwd = append(pwd, byte(l))
|
pwd = append(pwd, uint32(l))
|
||||||
}
|
}
|
||||||
return pwd
|
return pwd
|
||||||
}
|
}
|
||||||
|
|
||||||
func lenCode(msg []byte, key bool) []byte {
|
func lenCode(msg []uint32, key bool) []byte {
|
||||||
l := len(msg)
|
l := uint32(len(msg))
|
||||||
ll := (l - 1) << 2
|
ll := (l - 1) << 2
|
||||||
if key {
|
if key {
|
||||||
m := int(msg[l-1])
|
m := msg[l-1]
|
||||||
if m < ll-3 || m > ll {
|
if m < ll-3 || m > ll {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
ll = m
|
ll = m
|
||||||
}
|
}
|
||||||
|
var t []byte
|
||||||
for i := range msg {
|
for i := range msg {
|
||||||
msg[i] = byte(int(msg[i])&0xff) + byte(int(msg[i])>>8&0xff) + byte(int(msg[i])>>16&0xff) + byte(int(msg[i])>>24&0xff)
|
t = append(t, byte(msg[i]&0xff),byte(msg[i]>>8&0xff),byte(msg[i]>>16&0xff),byte(msg[i]>>24&0xff))
|
||||||
}
|
}
|
||||||
if key {
|
if key {
|
||||||
return msg[0:ll]
|
return t[0:ll]
|
||||||
}
|
}
|
||||||
return msg
|
return t
|
||||||
}
|
}
|
||||||
|
|
||||||
func XEncode(content string, key string) []byte {
|
func XEncode(content string, key string) []byte {
|
||||||
@@ -53,36 +54,36 @@ func XEncode(content string, key string) []byte {
|
|||||||
pwdk := sensCode(key, false)
|
pwdk := sensCode(key, false)
|
||||||
if len(pwdk) < 4 {
|
if len(pwdk) < 4 {
|
||||||
for i := 0; i < (4 - len(pwdk)); i++ {
|
for i := 0; i < (4 - len(pwdk)); i++ {
|
||||||
pwdk = append(pwdk, byte(0))
|
pwdk = append(pwdk, 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
n := len(pwd) - 1
|
var n = uint32(len(pwd) - 1)
|
||||||
z := pwd[n]
|
z := pwd[n]
|
||||||
y := pwd[0]
|
y := pwd[0]
|
||||||
c := 0x86014019 | 0x183639A0
|
var c uint32 = 0x86014019 | 0x183639A0
|
||||||
m := 0
|
var m uint32 = 0
|
||||||
e := 0
|
var e uint32 = 0
|
||||||
p := 0
|
var p uint32 = 0
|
||||||
q := math.Floor(6 + 52/(float64(n)+1))
|
q := math.Floor(6 + 52/(float64(n)+1))
|
||||||
d := 0
|
var d uint32 = 0
|
||||||
for 0 < q {
|
for 0 < q {
|
||||||
d = d + c&(0x8CE0D9BF|0x731F2640)
|
d = d + c&(0x8CE0D9BF|0x731F2640)
|
||||||
e = d >> 2 & 3
|
e = d >> 2 & 3
|
||||||
p = 0
|
p = 0
|
||||||
for p < n {
|
for p < n {
|
||||||
y = pwd[p+1]
|
y = pwd[p+1]
|
||||||
m = int(z)>>5 ^ int(y)<<2
|
m = z>>5 ^ y<<2
|
||||||
m = m + ((int(y)>>3 ^ int(z)<<4) ^ (d ^ int(y)))
|
m = m + ((y>>3 ^ z<<4) ^ (d ^ y))
|
||||||
m = m + (int(pwdk[(p&3)^e]) ^ int(z))
|
m = m + (pwdk[(p&3)^e] ^ z)
|
||||||
pwd[p] = byte(int(pwd[p]) + m&(0xEFB8D130|0x10472ECF))
|
pwd[p] = pwd[p] + m&(0xEFB8D130|0x10472ECF)
|
||||||
z = pwd[p]
|
z = pwd[p]
|
||||||
p = p + 1
|
p = p + 1
|
||||||
}
|
}
|
||||||
y = pwd[0]
|
y = pwd[0]
|
||||||
m = int(z)>>5 ^ int(y)<<2
|
m = z>>5 ^ y<<2
|
||||||
m = m + ((int(y)>>3 ^ int(z)<<4) ^ (int(d) ^ int(y)))
|
m = m + ((y>>3 ^ z<<4) ^ (d ^ y))
|
||||||
m = m + (int(pwdk[(p&3)^e]) ^ int(z))
|
m = m + (pwdk[(p&3)^e] ^ z)
|
||||||
pwd[n] = byte(int(pwd[n]) + m&(0xBB390742|0x44C6F8BD))
|
pwd[n] = pwd[n] + m&(0xBB390742|0x44C6F8BD)
|
||||||
z = pwd[n]
|
z = pwd[n]
|
||||||
q = q - 1
|
q = q - 1
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -26,11 +26,11 @@ func GetIp(body string) (string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func GetToken(body string) (string, error) {
|
func GetToken(body string) (string, error) {
|
||||||
return Search(body, "\"challenge\":\"(.*?)\"")
|
return Search("\"challenge\":\"(.*?)\"",body)
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetResult(body string)(string,error){
|
func GetResult(body string)(string,error){
|
||||||
return Search(body,"\"error_msg\":\"(.+)\"")
|
return Search("\"error\":\"(.+?)\"",body)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Md5(content string) string {
|
func Md5(content string) string {
|
||||||
|
|||||||
13
main.go
13
main.go
@@ -3,7 +3,6 @@ package main
|
|||||||
import (
|
import (
|
||||||
"Mmx/Request"
|
"Mmx/Request"
|
||||||
"Mmx/Util"
|
"Mmx/Util"
|
||||||
"encoding/base64"
|
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
@@ -52,15 +51,16 @@ func Generate(Domain string, Username string, Password string) *LoginInfo {
|
|||||||
func ErrHandler(err error) {
|
func ErrHandler(err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
defer os.Exit(3)
|
defer os.Exit(3)
|
||||||
|
fmt.Println("Error")
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
G := Generate(
|
G := Generate(
|
||||||
"",
|
"", //登录地址域名或ip
|
||||||
"",
|
"", //账号
|
||||||
"",
|
"", //密码
|
||||||
)
|
)
|
||||||
fmt.Println("Step1: Get local ip returned from srun server.")
|
fmt.Println("Step1: Get local ip returned from srun server.")
|
||||||
{
|
{
|
||||||
@@ -90,7 +90,7 @@ func main() {
|
|||||||
"enc_ver": G.Enc,
|
"enc_ver": G.Enc,
|
||||||
})
|
})
|
||||||
ErrHandler(err)
|
ErrHandler(err)
|
||||||
G.EncryptedInfo = "{SRBX1}" + base64.StdEncoding.EncodeToString(Util.XEncode(string(info), G.Token))
|
G.EncryptedInfo = "{SRBX1}" + Util.Base64(Util.XEncode(string(info), G.Token))
|
||||||
G.Md5=Util.Md5(G.Token)
|
G.Md5=Util.Md5(G.Token)
|
||||||
G.EncryptedMd5 = "{MD5}"+G.Md5
|
G.EncryptedMd5 = "{MD5}"+G.Md5
|
||||||
|
|
||||||
@@ -115,7 +115,7 @@ func main() {
|
|||||||
"chksum": G.EncryptedChkstr,
|
"chksum": G.EncryptedChkstr,
|
||||||
"n": G.N,
|
"n": G.N,
|
||||||
"type": G.VType,
|
"type": G.VType,
|
||||||
"os": "Windows+10",
|
"os": "Windows 10",
|
||||||
"name": "windows",
|
"name": "windows",
|
||||||
"double_stack": "0",
|
"double_stack": "0",
|
||||||
"_": "1602812428675",
|
"_": "1602812428675",
|
||||||
@@ -124,6 +124,5 @@ func main() {
|
|||||||
G.LoginResult,err=Util.GetResult(res)
|
G.LoginResult,err=Util.GetResult(res)
|
||||||
ErrHandler(err)
|
ErrHandler(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println("The loggin result is: " + G.LoginResult)
|
fmt.Println("The loggin result is: " + G.LoginResult)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user