本文整理匯總了Golang中Logger.Tracef函數的典型用法代碼示例。如果您正苦於以下問題:Golang Tracef函數的具體用法?Golang Tracef怎麽用?Golang Tracef使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Tracef函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: AnalyzeKLinePeroid
func (w *Huobi) AnalyzeKLinePeroid(symbol string, peroid int) (ret bool, records []Record) {
ret = false
var huobisymbol string
if symbol == "btc_cny" {
huobisymbol = "huobibtccny"
} else {
huobisymbol = "huobiltccny"
logger.Fatal("huobi does not support LTC by now, wait for huobi provide it.", huobisymbol)
return
}
req, err := http.NewRequest("GET", fmt.Sprintf(Config["hb_kline_url"], peroid), nil)
if err != nil {
logger.Fatal(err)
return
}
req.Header.Set("Referer", Config["hb_base_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
c := util.NewTimeoutClient()
logger.Tracef("HTTP req begin AnalyzeKLinePeroid")
resp, err := c.Do(req)
logger.Tracef("HTTP req end AnalyzeKLinePeroid")
if err != nil {
logger.Traceln(err)
return
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
logger.Tracef("HTTP returned status %v", resp)
return
}
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
logger.Traceln(resp.Header.Get("Content-Type"))
switch contentEncoding {
case "gzip":
body = util.DumpGZIP(resp.Body)
default:
bodyByte, err := ioutil.ReadAll(resp.Body)
if err != nil {
logger.Errorln("read the http stream failed")
return
} else {
body = string(bodyByte)
}
}
ioutil.WriteFile(fmt.Sprintf("cache/hbKLine_%03d.data", peroid), []byte(body), 0644)
return analyzePeroidLine(fmt.Sprintf("cache/hbKLine_%03d.data", peroid))
}
示例2: TradeKLinePeroid
func (w *Huobi) TradeKLinePeroid(peroid int) (ret bool) {
req, err := http.NewRequest("GET", fmt.Sprintf(Config["trade_kline_url"], peroid, rand.Float64()), nil)
if err != nil {
logger.Fatal(err)
return false
}
req.Header.Set("Referer", Config["trade_flash_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
if w.client == nil {
w.client = &http.Client{nil, nil, nil}
}
resp, err := w.client.Do(req)
if err != nil {
logger.Errorln(err)
return false
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, err := ioutil.ReadAll(resp.Body)
if err != nil {
logger.Errorln("read the http stream failed")
return false
} else {
body = string(bodyByte)
ioutil.WriteFile(fmt.Sprintf("cache/TradeKLine_%03d.data", peroid), bodyByte, os.ModeAppend)
}
}
logger.Traceln(resp.Header.Get("Content-Type"))
ret := strings.Contains(body, "您需要登錄才能繼續")
if ret {
logger.Traceln("您需要登錄才能繼續")
return false
} else {
return w.AnalyzePeroidLine(fmt.Sprintf("cache/TradeKLine_%03d.data", peroid), body)
}
} else {
logger.Tracef("HTTP returned status %v", resp)
}
return false
}
示例3: httpRequest
func (w *HuobiTrade) httpRequest(pParams map[string]string) (string, error) {
v := url.Values{}
for key, val := range pParams {
v.Add(key, val)
}
req, err := http.NewRequest("POST", Config["api_url"], strings.NewReader(v.Encode()))
if err != nil {
logger.Fatal(err)
return "", err
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", "https://www.huobi.com/")
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
w.client = new(http.Client)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
return "", err
}
defer resp.Body.Close()
logger.Tracef("api_url resp StatusCode=%v", resp.StatusCode)
logger.Tracef("api_url resp=%v", resp)
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
logger.Traceln(resp.Header.Get("Content-Type"))
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/api_url.json", bodyByte, os.ModeAppend)
}
logger.Traceln(body)
return body, nil
} else {
logger.Tracef("resp %v", resp)
}
return "", nil
}
示例4: getOrderBook
func (w *Okcoin) getOrderBook(symbol string) (ret bool, orderBook OrderBook) {
//init to false
ret = false
req, err := http.NewRequest("GET", fmt.Sprintf(Config["ok_depth_url"], symbol), nil)
if err != nil {
logger.Fatal(err)
return
}
req.Header.Set("Referer", Config["ok_base_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
c := util.NewTimeoutClient()
logger.Tracef("HTTP req begin getOrderBook")
resp, err := c.Do(req)
logger.Tracef("HTTP req end getOrderBook")
if err != nil {
logger.Traceln(err)
return
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
logger.Errorf("HTTP returned status %v", resp)
return
}
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = util.DumpGZIP(resp.Body)
default:
bodyByte, err := ioutil.ReadAll(resp.Body)
if err != nil {
logger.Errorln("read the http stream failed")
return
} else {
body = string(bodyByte)
ioutil.WriteFile("cache/okdepth.json", bodyByte, 0644)
}
}
return w.analyzeOrderBook(body)
}
示例5: parse_trade
func parse_trade(trades []interface{}, trades_data *[15]Trade) {
for k, v := range trades {
switch vt := v.(type) {
case map[string]interface{}:
logger.Traceln(k, " is a map:")
logger.Tracef("trades[%d]\n", k)
for ik, iv := range vt {
switch ik {
case "time":
trades_data[k].time = iv.(string)
case "price":
trades_data[k].price = InterfaceToFloat64(iv)
case "amount":
trades_data[k].amount = InterfaceToFloat64(iv)
case "type":
trades_data[k].type_ = iv.(string)
}
}
default:
logger.Errorln(k, v)
logger.Fatalln("don't know the type, crash!")
}
}
}
示例6: parse_topsell
func parse_topsell(topsells map[string]interface{}, topsells_data *[5]Top_buy_sell) {
index := 4
for k, v := range topsells {
switch vt := v.(type) {
case map[string]interface{}:
logger.Traceln(k, " is a map:")
logger.Tracef("topsells[%s]\n", k)
for ik, iv := range vt {
logger.Traceln(ik, iv)
switch ik {
case "price":
topsells_data[index].Price = InterfaceToFloat64(iv)
case "amount":
topsells_data[index].amount = InterfaceToFloat64(iv)
case "level":
topsells_data[index].level = InterfaceToFloat64(iv)
case "accu":
topsells_data[index].accu = InterfaceToFloat64(iv)
}
}
index--
default:
logger.Errorln(k, v)
logger.Fatalln("don't know the type, crash!")
}
}
}
示例7: getOrderBook
func (w *Huobi) getOrderBook(symbol string) (ret bool, hbOrderBook OrderBook) {
// init to false
ret = false
var huobisymbol string
if symbol == "btc_cny" {
huobisymbol = "huobibtccny"
} else {
huobisymbol = "huobiltccny"
logger.Fatal("huobi does not support LTC by now, wait for huobi provide it.", huobisymbol)
return
}
rnd := util.RandomString(20)
now := time.Now().UnixNano() / 1000000
req, err := http.NewRequest("GET", fmt.Sprintf(Config["hb_trade_detail"], rnd, now, now), nil)
if err != nil {
logger.Fatal(err)
return
}
req.Header.Set("Referer", Config["base_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
req.Header.Add("Accept-Encoding", "identity")
resp, err := http.DefaultClient.Do(req)
if err != nil {
logger.Traceln(err)
logger.Traceln(req)
logger.Traceln(resp)
return
}
defer resp.Body.Close()
if resp.StatusCode != 200 {
logger.Errorf("HTTP returned status %v", resp)
return
}
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = util.DumpGZIP(resp.Body)
default:
bodyByte, err := ioutil.ReadAll(resp.Body)
if err != nil {
logger.Errorln("read the http stream failed")
return
} else {
body = string(bodyByte)
ioutil.WriteFile("cache/OrderBook.json", bodyByte, 0644)
}
}
return w.analyzeOrderBook(body)
}
示例8: httpRequest
func (w *OkcoinTrade) httpRequest(api_url string, pParams map[string]string) (string, error) {
pParams["sign"] = w.createSign(pParams)
v := url.Values{}
for key, val := range pParams {
v.Add(key, val)
}
req, err := http.NewRequest("POST", api_url, strings.NewReader(v.Encode()))
if err != nil {
logger.Fatal(err)
return "", err
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", "https://www.okcoin.cn/")
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
c := util.NewTimeoutClient()
logger.Tracef("HTTP req begin OkcoinTrade")
resp, err := c.Do(req)
logger.Tracef("HTTP req end OkcoinTrade")
if err != nil {
logger.Fatal(err)
return "", err
}
defer resp.Body.Close()
logger.Tracef("api_url resp StatusCode=%v", resp.StatusCode)
logger.Tracef("api_url resp=%v", resp)
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
logger.Traceln(resp.Header.Get("Content-Type"))
switch contentEncoding {
case "gzip":
body = util.DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/okapi_url.json", bodyByte, 0644)
}
return body, nil
} else {
logger.Tracef("resp %v", resp)
}
return "", nil
}
示例9: parse_buy_sell
func parse_buy_sell(sells_buys []interface{}, sells_buys_data *[10]SellBuy) {
for k, v := range sells_buys {
switch vt := v.(type) {
case map[string]interface{}:
logger.Traceln(k, " is a map:")
logger.Tracef("sells/buys[%d]\n", k)
for ik, iv := range vt {
switch ik {
case "price":
sells_buys_data[k].price = InterfaceToFloat64(iv)
case "level":
sells_buys_data[k].level = InterfaceToFloat64(iv)
case "amount":
sells_buys_data[k].amount = InterfaceToFloat64(iv)
}
}
default:
logger.Errorln(k, v)
logger.Fatalln("don't know the type, crash!")
}
}
}
示例10: Login
func (w *Huobi) Login() bool {
login_url := Config["login_url"]
email := Config["email"]
password := Config["password"]
post_arg := url.Values{"email": {email}, "password": {password}}
//logger.Traceln(strings.NewReader(post_arg.Encode()))
req, err := http.NewRequest("POST", login_url, strings.NewReader(post_arg.Encode()))
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", "https://www.huobi.com/")
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
//jar := NewJar()
jar, _ := cookiejar.New(nil)
w.client = &http.Client{nil, nil, jar}
//w.client = new(http.Client)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
}
defer resp.Body.Close()
logger.Tracef("Login resp StatusCode=%v", resp.StatusCode)
logger.Tracef("Login resp=%v", resp)
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/login.html", bodyByte, os.ModeAppend)
}
logger.Traceln(resp.Header.Get("Content-Type"))
ret := strings.Contains(body, "用戶名或者密碼錯誤")
if ret {
logger.Traceln("用戶名或者密碼錯誤")
return false
}
w.isLogin = true
return true
} else if resp.StatusCode == 500 {
w.isLogin = true
return true
} else {
logger.Tracef("resp %v", resp)
}
return false
}
示例11: TradeDetail
func (w *Huobi) TradeDetail() (ret bool) {
rnd := RandomString(20)
now := time.Now().UnixNano() / 1000000
req, err := http.NewRequest("GET", fmt.Sprintf(Config["trade_detail"], rnd, now, now), nil)
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Referer", Config["base_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
req.Header.Add("Accept-Encoding", "identity")
resp, err := http.DefaultClient.Do(req)
if err != nil {
logger.Traceln(err)
logger.Traceln(req)
logger.Traceln(resp)
return false
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, err := ioutil.ReadAll(resp.Body)
if err != nil {
logger.Errorln("read the http stream failed")
return false
} else {
body = string(bodyByte)
ioutil.WriteFile("cache/TradeDetail.json", bodyByte, os.ModeAppend)
}
}
logger.Traceln(resp.Header.Get("Content-Type"))
if resp.Header.Get("Content-Type") == "application/json" {
doc := json.NewDecoder(strings.NewReader(body))
type Msg struct {
Code int
Msg string
}
var m Msg
if err := doc.Decode(&m); err == io.EOF {
logger.Traceln(err)
} else if err != nil {
logger.Fatal(err)
}
logger.Traceln(m)
if m.Code == 0 {
return true
} else {
logger.Errorln(m)
return false
}
} else {
ret := strings.Contains(body, "您需要登錄才能繼續")
if ret {
logger.Errorln("您需要登錄才能繼續")
logger.Errorln(body)
return false
} else {
return w.TradeDetailAnalyze(body)
}
}
} else {
logger.Errorf("HTTP returned status %v", resp)
}
logger.Errorln("why in here?")
return false
}
示例12: TradeDelegation
func (w *Huobi) TradeDelegation() bool {
fmt.Println(w.isLogin)
if w.isLogin == false {
if w.Login() == false {
return false
}
}
req, err := http.NewRequest("GET", Config["trade_delegation"], nil)
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", Config["trade_add_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
req.Header.Add("X-Requested-With", "XMLHttpRequest")
logger.Traceln(req)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/TradeDelegation.html", bodyByte, os.ModeAppend)
}
logger.Traceln(resp.Header.Get("Content-Type"))
if resp.Header.Get("Content-Type") == "application/json" {
doc := json.NewDecoder(strings.NewReader(body))
type Msg struct {
Code int
Msg string
}
for {
var m Msg
if err := doc.Decode(&m); err == io.EOF {
logger.Traceln(err)
break
} else if err != nil {
logger.Fatal(err)
}
logger.Traceln(m)
if m.Code == 0 {
return true
} else {
return false
}
}
return false
} else {
ret := strings.Contains(body, "您需要登錄才能繼續")
if ret {
logger.Traceln("您需要登錄才能繼續")
w.isLogin = false
return false
} else {
return w.TradeDelegationAnalyze(body)
}
}
} else {
logger.Tracef("HTTP returned status %v", resp)
}
return false
}
示例13: QueryMyTradeInfo
func (w *Huobi) QueryMyTradeInfo() bool {
fmt.Println(w.isLogin)
if w.isLogin == false {
if w.Login() == false {
return false
}
}
req, err := http.NewRequest("GET", fmt.Sprintf(Config["my_trade_info"], rand.Float64()), nil)
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", Config["trade_query_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
req.Header.Add("X-Requested-With", "XMLHttpRequest")
logger.Traceln(req)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/MyTradeInfo.json", bodyByte, os.ModeAppend)
}
logger.Traceln(resp.Header.Get("Content-Type"))
if resp.Header.Get("Content-Type") == "application/json" {
w.TradeMyTradeInfoAnalyze(body)
if w.MyTradeInfo.Code == 0 {
return true
} else {
return false
}
} else {
ret := strings.Contains(body, "您需要登錄才能繼續")
if ret {
logger.Traceln("您需要登錄才能繼續")
w.isLogin = false
return false
} else {
return true
}
}
} else {
logger.Tracef("HTTP returned status %v", resp)
}
return false
}
示例14: TradeUpdate
func (w *Huobi) TradeUpdate(id, price, amount string) bool {
post_arg := url.Values{
"id": {id},
"price": {price},
"amount": {amount},
}
req, err := http.NewRequest("POST", Config["trade_update_url"], strings.NewReader(post_arg.Encode()))
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", "https://www.huobi.com/")
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
req.Header.Add("X-Requested-With", "XMLHttpRequest")
logger.Traceln(req)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
}
defer resp.Body.Close()
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("cache/TradeUpdate.json", bodyByte, os.ModeAppend)
}
logger.Traceln(resp.Header.Get("Content-Type"))
if resp.Header.Get("Content-Type") == "application/json" {
doc := json.NewDecoder(strings.NewReader(body))
type Msg struct {
Code int
Msg string
}
var m Msg
if err := doc.Decode(&m); err == io.EOF {
logger.Traceln(err)
} else if err != nil {
logger.Fatal(err)
}
logger.Traceln(m)
if m.Code == 0 {
return true
} else {
return false
}
} else {
ret := strings.Contains(body, "您需要登錄才能繼續")
if ret {
logger.Traceln("您需要登錄才能繼續")
w.isLogin = false
return false
} else {
return true
}
}
} else {
logger.Tracef("HTTP returned status %v", resp)
}
return false
}
示例15: Login
/*
txcode := map[int]string{
0: `買單已委托,<a href="/trade/index.php?a=delegation">查看結果</a>`,
2: `沒有足夠的人民幣`,
10: `沒有足夠的比特幣`,
16: `您需要登錄才能繼續`,
17: `沒有權限`,
42: `該委托已經取消,不能修改`,
44: `交易價錢太低`,
56:`賣出價格不能低於限價的95%`}
logger.Traceln(txcode[m.Code])
*/
func (w *BitvcTrade) Login() bool {
login_url := Config["bitvc_login_url"]
email := Config["bitvc_email"]
clear_password := Config["bitvc_password"]
password := util.Md5(clear_password + "hi,pwd")
/*
function calc_password_security_score(t) {
var e = 0;
return t.length < 4 ? e :
(t.length >= 8 && e++, t.length >= 10 && e++, /[a-z]/.test(t) && /[A-Z]/.test(t) && e++, /[0-9]/.test(t) && e++, /.[!,@,#,$,%,^,&,*,?,_,~, -,£,(,)]/.test(t) && e++, e)
}*/
var pwd_security_score int
if len(clear_password) < 4 {
pwd_security_score = 0
} else if len(clear_password) >= 8 {
pwd_security_score++
if len(clear_password) >= 10 {
pwd_security_score++
}
}
//fuck正則,不玩了!
reg := regexp.MustCompile(`[[:ascii:]]`)
fmt.Printf("%q\n", reg.FindAllString(password, -1))
// ["H" " 世界!123 G" "."]
str_pwd_security_score := fmt.Sprintf("%d", pwd_security_score)
post_arg := url.Values{"email": {email}, "password": {password}, "backurl": {"/index/index"}, "pwd_security_score": {str_pwd_security_score}}
//logger.Traceln(strings.NewReader(post_arg.Encode()))
req, err := http.NewRequest("POST", login_url, strings.NewReader(post_arg.Encode()))
if err != nil {
logger.Fatal(err)
}
req.Header.Set("Content-Type", "application/x-www-form-urlencoded")
req.Header.Set("Referer", Config["bitvc_base_url"])
req.Header.Add("Connection", "keep-alive")
req.Header.Add("User-Agent", "Mozilla/5.0 (Windows NT 5.1) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/31.0.1650.63 Safari/537.36")
logger.Traceln(req)
//jar := NewJar()
jar, _ := cookiejar.New(nil)
w.client = &http.Client{nil, nil, jar}
//w.client = new(http.Client)
resp, err := w.client.Do(req)
if err != nil {
logger.Fatal(err)
}
defer resp.Body.Close()
logger.Tracef("Login resp StatusCode=%v", resp.StatusCode)
logger.Tracef("Login resp=%v", resp)
if resp.StatusCode == 200 {
var body string
contentEncoding := resp.Header.Get("Content-Encoding")
logger.Tracef("HTTP returned Content-Encoding %s", contentEncoding)
switch contentEncoding {
case "gzip":
body = DumpGZIP(resp.Body)
default:
bodyByte, _ := ioutil.ReadAll(resp.Body)
body = string(bodyByte)
ioutil.WriteFile("login.html", bodyByte, os.ModeAppend)
}
logger.Traceln(resp.Header.Get("Content-Type"))
ret := strings.Contains(body, "用戶名或者密碼錯誤")
if ret {
logger.Traceln("用戶名或者密碼錯誤")
return false
}
w.isLogin = true
return true
} else if resp.StatusCode == 500 {
w.isLogin = true
return true
} else {
logger.Tracef("resp %v", resp)
}
return false
}