Browse Source

修复抢购提交订单数组越界问题

main
ztino 4 years ago
parent
commit
142dfd7077
  1. 47
      jd_seckill/seckill.go

47
jd_seckill/seckill.go

@ -77,20 +77,6 @@ func (this *Seckill) getSeckillUrl() (string, error) {
url := "" url := ""
for { for {
_, body, _ := req.Send().End() _, body, _ := req.Send().End()
//临时打印数据
log.Println("返回信息:"+body)
//先注释,测试过gjson可以解析jQuery1153906({"type":"3","state":"13","url":""})格式
/* var cbBody string
cbBody = body
spBody := strings.Split(body, "(")
if len(spBody) >= 2 {
cbBody = strings.Trim(spBody[1], ")")
}
if gjson.Get(cbBody, "url").Exists() && gjson.Get(cbBody, "url").String() != "" {
url = gjson.Get(cbBody, "url").String()
break
}*/
if gjson.Get(body, "url").Exists() && gjson.Get(body, "url").String() != "" { if gjson.Get(body, "url").Exists() && gjson.Get(body, "url").String() != "" {
url = gjson.Get(body, "url").String() url = gjson.Get(body, "url").String()
break break
@ -158,16 +144,23 @@ func (this *Seckill) SeckillInitInfo() (string, error) {
req.SetData("sku", skuId) req.SetData("sku", skuId)
req.SetData("num", seckillNum) req.SetData("num", seckillNum)
req.SetData("isModifyAddress", "false") req.SetData("isModifyAddress", "false")
resp, body, err := req.SetUrl("https://marathon.jd.com/seckillnew/orderService/pc/init.action").SetMethod("post").Send().End() req.SetUrl("https://marathon.jd.com/seckillnew/orderService/pc/init.action").SetMethod("post")
if err != nil || resp.StatusCode != http.StatusOK { //尝试获取三次
log.Println("初始化秒杀信息失败") errorCount:=3
return "", errors.New("初始化秒杀信息失败") errorMsg:=""
} for errorCount > 0 {
if !gjson.Valid(body) { _, body, _ := req.Send().End()
log.Println("抢购失败,返回信息:" + body) if body!="null" && gjson.Valid(body) {
return "", errors.New("抢购失败,返回信息:" + body) log.Println("获取秒杀初始化信息成功")
return body,nil
}else{
log.Println("获取秒杀初始化信息失败,返回信息:"+body)
errorMsg=body
}
errorCount=errorCount-1
time.Sleep(300*time.Millisecond)
} }
return body, nil return "", errors.New(errorMsg)
} }
func (this *Seckill) SubmitSeckillOrder() bool { func (this *Seckill) SubmitSeckillOrder() bool {
@ -182,6 +175,10 @@ func (this *Seckill) SubmitSeckillOrder() bool {
return false return false
} }
address := gjson.Get(initInfo, "addressList").Array() address := gjson.Get(initInfo, "addressList").Array()
if !gjson.Get(initInfo, "addressList").Exists() || len(address)<1 {
log.Println("抢购失败,可能你还未设置默认收货地址")
return false
}
defaultAddress := address[0] defaultAddress := address[0]
isinvoiceInfo := gjson.Get(initInfo, "invoiceInfo").Exists() isinvoiceInfo := gjson.Get(initInfo, "invoiceInfo").Exists()
invoiceTitle := "-1" invoiceTitle := "-1"
@ -241,6 +238,10 @@ func (this *Seckill) SubmitSeckillOrder() bool {
_ = service.SendMessage(this.conf, "茅台抢购通知", "抢购失败,网络错误") _ = service.SendMessage(this.conf, "茅台抢购通知", "抢购失败,网络错误")
return false return false
} }
//临时打印数据
log.Println("返回信息:"+body)
if !gjson.Valid(body) { if !gjson.Valid(body) {
log.Println("抢购失败,返回信息:" + body) log.Println("抢购失败,返回信息:" + body)
_ = service.SendMessage(this.conf, "茅台抢购通知", "抢购失败,返回信息:"+body) _ = service.SendMessage(this.conf, "茅台抢购通知", "抢购失败,返回信息:"+body)

Loading…
Cancel
Save