为了微信小程序的推广,微信提供了多种小程序入口方式,比如在公众号中可以将已经关联过的小程序的页面放置到自定义菜单中,用户单击后就可以打开小程序的相关页面;或者是给用户发送公众号模板消息,用户点击收到的模板消息进入小程序。不过这些方式都需要微信客户端的支持,有些情况下您可能希望在微信客户端之外的APP中打开小程序,比如您可能通过短信或者邮件给用户发送营销通知,并希望用户在短信或邮件APP中打开小程序,以快速获取用户流量,完成引流、导购等目的。对于这种诉求,微信也给予了支持,下面介绍如何生成URL Scheme以及通过URL Scheme打开小程序的方法。
返回小程序URL Scheme码
type WxJumpWxa struct {
Path string `json:"path"`//通过scheme码进入的小程序页面路径
Query string `json:"query"` //通过scheme码进入小程序时的query
}
type WxUrlSchemeReq struct {
Jump_wxa WxJumpWxa `json:"jump_wxa"`//跳转到的目标小程序信息
Is_expire bool `json:"is_expire"` //到期失效:true,永久有效:false
Expire_type int64 `json:"expire_type"`//失效时间:0,失效间隔天数:1
Expire_time int64 `json:"expire_time"`//到期失效的 scheme 码的失效时间,为 Unix 时间戳
Expire_interval int64 `json:"expire_interval"`//到期失效的 scheme 码的失效间隔天数
}
type WxUrlSchemeRet struct {
ErrCode int64 `json:"errcode"`
ErrMsg string `json:"errmsg"`
Openlink string `json:"openlink"`
}
//生成页面Scheme码
func HandlerUrlScheme(w http.ResponseWriter, r *http.Request) {
//page路径必须为已发布的小程序页面路径
page := r.FormValue("page");
//通过scheme码进入小程序时的query
query := r.FormValue("query");
var req WxUrlSchemeReq
req.Is_expire = true
req.Expire_type = 0
req.Expire_time = time.Now().AddDate(0, 0, 30).Unix()
req.Jump_wxa.Path = page
req.Jump_wxa.Query = query
paramstr, _ := json.Marshal(req)
fmt.Println(string(paramstr))
wx_addr := "https://api.weixin.qq.com/wxa/generatescheme"
wx_addr += "?access_token=" + GetWxToken()
fmt.Println(wx_addr)
res, err := http.Post(wx_addr, "charset=UTF-8", bytes.NewBuffer(paramstr))
if err != nil {
fmt.Println(err)
http.Error(w, "微信请求错误", http.StatusInternalServerError)
return
}
raw, err := ioutil.ReadAll(res.Body)
res.Body.Close()
if err != nil {
fmt.Println(err)
http.Error(w, "微信返回错误", http.StatusInternalServerError)
return
}
fmt.Println(string(raw))
var ret WxUrlSchemeRet
err = json.Unmarshal(raw, &ret)
if err != nil {
fmt.Println(err)
http.Error(w, "微信返回错误", http.StatusInternalServerError)
return
}
w.Write([]byte(ret.Openlink))
}
urlscheme.generate生成的URL Scheme如下所示:
weixin://dl/business/?t= *TICKET*
IOS系统支持识别URL Scheme,可在短信等应用场景中直接通过URL Scheme跳转小程序。Android系统不支持直接识别URL Scheme,用户无法通过URL Scheme正常打开小程序。开发者需要使用H5页面中转,再跳转到URL Scheme来打开小程序,跳转连接的格式如下所示:
location.href = 'weixin://dl/business/?t= *TICKET*'
但是当我们短信或邮件中打开跳转链接时,是无法确定用户所使用的的手机设备是IOS还是Android,因此我们从实际的业务触发,都需要一个H5页面进行中转处理。
说明: