|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"crypto/rc4"
|
|
|
|
"encoding/hex"
|
|
|
|
"goInOut/utils"
|
|
|
|
"log"
|
|
|
|
"testing"
|
|
|
|
"text/template"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCRC16CCITT(t *testing.T) {
|
|
|
|
hexs := "0a16080718a8ea8fab06620c0a0471bd54c11204e01d8641"
|
|
|
|
hexs = "0a2f080210f8b6d5d01218b395bffec3313a1e0a08a75fed41a75fed41120892c5d64292c5d6421a08f6c8a74379c9a743"
|
|
|
|
Hexdata, _ := hex.DecodeString(hexs)
|
|
|
|
crc := utils.NewCRC16CCITT().GetWCRCin(Hexdata)
|
|
|
|
log.Println(hex.EncodeToString(crc))
|
|
|
|
log.Println("===1==")
|
|
|
|
needRC4 := append(Hexdata, crc...)
|
|
|
|
rc4Key := []byte("t/500101")
|
|
|
|
dest1 := make([]byte, len(needRC4))
|
|
|
|
cipher1, _ := rc4.NewCipher(rc4Key)
|
|
|
|
cipher1.XORKeyStream(dest1, needRC4)
|
|
|
|
log.Printf("最终报文 dest1=%s", hex.EncodeToString(dest1))
|
|
|
|
|
|
|
|
}
|
|
|
|
func TestRC4(t *testing.T) {
|
|
|
|
rc4Key := []byte("t/500101")
|
|
|
|
log.Println("===2 test RC4==")
|
|
|
|
cipher2, _ := rc4.NewCipher(rc4Key)
|
|
|
|
raw := "0a2f080210f8b6d5d01218b395bffec3313a1e0a08a75fed41a75fed41120892c5d64292c5d6421a08f6c8a74379c9a743864c"
|
|
|
|
needRC4New, _ := hex.DecodeString(raw)
|
|
|
|
dest2 := make([]byte, len(needRC4New))
|
|
|
|
cipher2.XORKeyStream(dest2, needRC4New)
|
|
|
|
log.Printf("最终报文 dest1=%s", hex.EncodeToString(dest2))
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestTemplate(t *testing.T) {
|
|
|
|
Create := func(name, t string) *template.Template {
|
|
|
|
return template.Must(template.New(name).Parse(t))
|
|
|
|
}
|
|
|
|
t2 := Create("t2", "什么是快乐星球-Name: {{.Name}}\n")
|
|
|
|
b := &bytes.Buffer{}
|
|
|
|
t2.Execute(b, struct {
|
|
|
|
Name string
|
|
|
|
}{"Jane Doe"})
|
|
|
|
time.Sleep(time.Second * 1)
|
|
|
|
bs := b.String()
|
|
|
|
log.Println(bs)
|
|
|
|
}
|