不同项目之前,通过http访问,进行数据沟通
先设定一个接口,确认外部能访问到
PHP写一个接口
public function ceshi_return()
{$data = $this->request->param();$id = $data['id'];$res = Db::name('user')->field('id,status,price,name')->where(['id'=>$id])->find();$this->ajaxReturn($res);
}
返回效果:
get方式访问外部的接口
封装的函数
package utils
func GetRequest(url string) string {client := &http.Client{Timeout: 5 * time.Second}resp, err := client.Get(url)if err != nil {panic(err)}defer resp.Body.Close()result, _ := ioutil.ReadAll(resp.Body)return string(result)
}
上层访问接口
因为要将请求到的数据,进行处理,所以需要提前定义一个结构体来接受处理这些数据
type GetData struct {Id int `json:"id"`Status int `json:"status"`Price int `json:"price"`Name string `json:"name"`
}func GetUserData(c *gin.Context) {id := c.PostForm("id")url := "https://www.xxxx.com/admin/login/ceshi_return?id=" + iddata := utils.GetRequest(url)d := []byte(data)var g GetData_ = json.Unmarshal(d, &g)c.JSON(http.StatusOK, gin.H{"code": 200,"msg": "查询成功","data": g,})}
效果
Post方式请求外部接口
封装函数
这里的访问方式,我写死了,设置成了json格式,有其他的方式,可以根据自己需求修改
package utils
func PostRequest(url string, data interface{}) string {client := &http.Client{Timeout: 5 * time.Second}jsonStr, _ := json.Marshal(data)resp, err := client.Post(url, "application/json", bytes.NewBuffer(jsonStr))if err != nil {panic(err)}defer resp.Body.Close()result, _ := ioutil.ReadAll(resp.Body)return string(result)
}
访问函数
//采用结构体的方式,来装要发送的数据
type PostData struct {Id int `json:"id"`
}// 访问外部地址
func PostUserData(c *gin.Context) {id := c.PostForm("id")var p PostDatap.Id, _ = strconv.Atoi(id)url := "https://www.xxxx.com/admin/login/ceshi_return"data := utils.PostRequest(url, p)fmt.Print(data)d := []byte(data)var g GetData_ = json.Unmarshal(d, &g)c.JSON(http.StatusOK, gin.H{"code": 200,"msg": "查询成功","data": g,})}
效果