Browse Source

Merge branch 'master' of http://git.shengws.com/csx/gdyb

csx 2 years ago
parent
commit
5e8a3cc86a
2 changed files with 117 additions and 13 deletions
  1. 45 13
      controllers/nm/nm_controller.go
  2. 72 0
      service/gdyb_service.go

+ 45 - 13
controllers/nm/nm_controller.go View File

@@ -40,6 +40,15 @@ func NmybRegistRouters() {
40 40
 	beego.Router("/nmyb/readcard", &NmController{}, "get:ReadCard")
41 41
 }
42 42
 
43
+type ReadCardResult struct {
44
+	Output struct {
45
+		CardInfo   string `json:"cardInfo"`
46
+		RegionCode string `json:"regionCode"`
47
+	} `json:"output"`
48
+	Code   int    `json:"CODE"`
49
+	ErrMsg string `json:"ERRMSG"`
50
+}
51
+
43 52
 type ELeData struct {
44 53
 	Data struct {
45 54
 		IdNo        string `json:"idNo"`
@@ -60,7 +69,7 @@ type ELeData struct {
60 69
 type ResultTwo struct {
61 70
 	ErrMsg      string `json:"err_msg"`
62 71
 	InfRefmsgid string `json:"inf_refmsgid"`
63
-	Infcode     int64  `json:"infcode"`
72
+	Infcode     string `json:"infcode"`
64 73
 	Output      struct {
65 74
 		Baseinfo struct {
66 75
 			Age         float64 `json:"age"`
@@ -487,13 +496,32 @@ func (c *NmController) ReadCard() {
487 496
 			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeReadCardException)
488 497
 			return
489 498
 		}
499
+
500
+		var dat2 map[string]interface{}
501
+		if err := json.Unmarshal([]byte(basStr), &dat2); err == nil {
502
+			fmt.Println(dat2)
503
+		} else {
504
+			fmt.Println(err)
505
+		}
506
+
507
+		userJSONBytes, _ := json.Marshal(dat2)
508
+		var res ReadCardResult
509
+		if err := json.Unmarshal(userJSONBytes, &res); err != nil {
510
+			utils.ErrorLog("解析失败:%v", err)
511
+			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
512
+			return
513
+		}
514
+
490 515
 		fmt.Println(basStr)
491
-		bas := strings.Split(basStr, "|")
516
+		bas := strings.Split(res.Output.CardInfo, "|")
492 517
 		basNumber := bas[1]
493 518
 		fmt.Println(basNumber)
494 519
 		card_sn := bas[3]
495 520
 		fmt.Println(card_sn)
496
-		result := service.Gdyb1101B(basNumber, org_name, operator, fixmedins_code, insuplc_admdvs, mdtrtarea_admvs, secret_key, 1, card_sn, 1)
521
+		cardNumber := bas[2]
522
+		name := bas[4]
523
+
524
+		result := service.Gdyb1101G(basNumber, org_name, operator, fixmedins_code, insuplc_admdvs, mdtrtarea_admvs, secret_key, 1, card_sn, 1, name)
497 525
 		var dat map[string]interface{}
498 526
 		if err := json.Unmarshal([]byte(result), &dat); err == nil {
499 527
 			fmt.Println(dat)
@@ -501,21 +529,22 @@ func (c *NmController) ReadCard() {
501 529
 			fmt.Println(err)
502 530
 		}
503 531
 
504
-		userJSONBytes, _ := json.Marshal(dat)
505
-		var res ResultTwo
506
-		if err := json.Unmarshal(userJSONBytes, &res); err != nil {
532
+		userJSONBytes2, _ := json.Marshal(dat)
533
+		var res2 ResultTwo
534
+		if err := json.Unmarshal(userJSONBytes2, &res2); err != nil {
507 535
 			utils.ErrorLog("解析失败:%v", err)
508 536
 			c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeDataException)
509 537
 			return
510 538
 		}
539
+		infocode, _ := strconv.ParseInt(res2.Infcode, 10, 64)
511 540
 
512
-		if res.Infcode == 0 {
541
+		if infocode == 0 {
513 542
 
514 543
 			var insutypes []string
515 544
 			var insutype string
516 545
 			var is390 int = 0
517 546
 			var is310 int = 0
518
-			for _, item := range res.Output.Iinfo {
547
+			for _, item := range res2.Output.Iinfo {
519 548
 				if (item.Insutype == "390" && item.PsnInsuStas == "1") || (item.Insutype == "310" && item.PsnInsuStas == "1") {
520 549
 					insutypes = append(insutypes, item.Insutype)
521 550
 				}
@@ -553,10 +582,11 @@ func (c *NmController) ReadCard() {
553 582
 
554 583
 			} else {
555 584
 				c.ServeSuccessJSON(map[string]interface{}{
556
-					"patient":  patient,
557
-					"number":   basNumber,
558
-					"info":     res,
559
-					"insutype": insutype,
585
+					"patient":     patient,
586
+					"number":      basNumber,
587
+					"info":        res,
588
+					"insutype":    insutype,
589
+					"card_number": cardNumber,
560 590
 				})
561 591
 			}
562 592
 		} else {
@@ -591,7 +621,9 @@ func (c *NmController) ReadCard() {
591 621
 				return
592 622
 			}
593 623
 
594
-			if res.Infcode == 0 {
624
+			infocode, _ := strconv.ParseInt(res.Infcode, 10, 64)
625
+
626
+			if infocode == 0 {
595 627
 				patient, err := service.GetPatientByNumber(ele.Data.IdNo, c.GetAdminUserInfo().CurrentOrgId)
596 628
 				if err == gorm.ErrRecordNotFound {
597 629
 					c.ServeFailJSONWithSGJErrorCode(enums.ErrorCodeNoPateintException)

+ 72 - 0
service/gdyb_service.go View File

@@ -3727,6 +3727,78 @@ func Gdyb1101B(certNo string, org_name string, doctor string, fixmedins_code str
3727 3727
 	return str
3728 3728
 }
3729 3729
 
3730
+func Gdyb1101G(certNo string, org_name string, doctor string, fixmedins_code string, insuplc_admdvs string, mdtrtarea_admvs string, secret_key string, id_card_type int64, card_sn string, certificates int64, name string) string {
3731
+	//生成签名
3732
+	nonce := GetRandomString(32)
3733
+	timestamp := time.Now().Unix()
3734
+	signature := setSignature(timestamp, nonce, secret_key)
3735
+	//生成输入报文
3736
+	inputMessage := SetInputMessage(nonce, timestamp, org_name, doctor, fixmedins_code, insuplc_admdvs, mdtrtarea_admvs)
3737
+	input := make(map[string]interface{})
3738
+	inputData := make(map[string]interface{})
3739
+	inputMessage["infno"] = "1101" // 交易编码
3740
+
3741
+	inputData["mdtrt_cert_type"] = "03" // 就诊凭证类型
3742
+	inputData["card_sn"] = card_sn      // 卡识别码
3743
+	inputData["certno"] = certNo        // 证件号码
3744
+	inputData["psn_cert_type"] = "01"   // 人员证件类型
3745
+	inputData["mdtrt_cert_no"] = certNo // 就诊凭证编号
3746
+	inputData["begntime"] = ""          // 开始时间
3747
+	inputData["psn_name"] = name        // 人员姓名
3748
+	input["data"] = inputData
3749
+	inputMessage["input"] = input //交易输入
3750
+
3751
+	bytesData, err := json.Marshal(inputMessage)
3752
+	fmt.Println(string(bytesData))
3753
+	if err != nil {
3754
+		fmt.Println(err.Error())
3755
+		return err.Error()
3756
+	}
3757
+	reader := bytes.NewReader(bytesData)
3758
+	gdyb_url := beego.AppConfig.String("gdyb_url")
3759
+	gdyb_paasid := beego.AppConfig.String("gdyb_paasid")
3760
+
3761
+	//url := "http://igb.hsa.gdgov.cn/ebus/gdyb_api/prd/hsa/hgs/1101"
3762
+	//url := gdyb_url + "1101"
3763
+	var url string
3764
+	if fixmedins_code == "H15049901371" {
3765
+		url = gdyb_url
3766
+	} else {
3767
+		url = gdyb_url + "1101"
3768
+	}
3769
+
3770
+	fmt.Println(url)
3771
+	fmt.Println(gdyb_paasid)
3772
+	fmt.Println(secret_key)
3773
+	//url := "http://igb.hsa.gdgov.cn/ebus/gdyb_inf/poc/hsa/hgs/1101"
3774
+	request, err := http.NewRequest("POST", url, reader)
3775
+	if err != nil {
3776
+		fmt.Println(err.Error())
3777
+		return err.Error()
3778
+	}
3779
+
3780
+	request.Header.Set("Content-Type", "application/json;charset=UTF-8")
3781
+	request.Header.Set("x-tif-paasid", gdyb_paasid)
3782
+	request.Header.Set("x-tif-signature", signature)
3783
+	request.Header.Set("x-tif-timestamp", strconv.FormatInt(timestamp, 10))
3784
+	request.Header.Set("x-tif-nonce", nonce)
3785
+
3786
+	client := http.Client{}
3787
+	resp, err := client.Do(request)
3788
+	if err != nil {
3789
+		fmt.Println(err.Error())
3790
+		return err.Error()
3791
+	}
3792
+	respBytes, err := ioutil.ReadAll(resp.Body)
3793
+	if err != nil {
3794
+		fmt.Println(err.Error())
3795
+		return err.Error()
3796
+	}
3797
+	fmt.Println(string(respBytes))
3798
+	str := string(respBytes)
3799
+	return str
3800
+}
3801
+
3730 3802
 func Gdyb1101ForEleCert(certNo string, org_name string, doctor string, fixmedins_code string, insuplc_admdvs string, mdtrtarea_admvs string, secret_key string, token string, name string) string {
3731 3803
 	//生成签名
3732 3804
 	nonce := GetRandomString(32)