从基础库 2.19.2 开始支持
开发者调用wx.request时,可以开启移动解析HttpDNS服务。 该服务基于Http协议向服务商的DNS服务器发送域名解析请求,替代了基于DNS协议向运营商Local DNS发起解析请求的传统方式,可以避免Local DNS造成的域名劫持和跨网访问问题,解决移动互联网服务中域名解析异常带来的困扰。
前往微信服务平台选购HttpDNS资源,并在服务详情页-接入文档获取Service ID。
小程序调用wx.request,将enableHttpDNS参数设置为true,并在httpDNSServiceId参数中填入选用的服务商Service ID。
wx.request({ url: 'example.php', //仅为示例,并非真实的接口地址 enableHttpDNS: true, httpDNSServiceId: 'wxa410372c837a5f26', success(res) { console.log('request success', res) }, fail(res) { console.error('request fail', res) }})
使用服务所产生的费用会按照实际调用服务商接口情况进行计费,定价策略由服务提供方制定,开发者需自行前往微信服务平台进行购买、续费等操作。
微信侧每次代开发者调用服务商接口时,微信侧会进行缓存,缓存策略由服务商返回的ttl决定,因此不一定每次调用request接口都会产生费用。
若开发者的服务可用额度为0,仍在wx.request接口中声明使用服务商提供的移动解析能力时,会触发报错,请开发者根据错误码妥善处理。
错误码 | 说明 |
---|---|
600000 | 网络错误 |
602000 | 网络请求错误 |
602001 | 系统错误 |
602002 | http请求httpdns服务商错误 |
602101 | 小程序未在服务市场购买httpdns服务 |
602102 | 小程序在httpdns服务市场资源包过期 |
602103 | 小程序在httpdns服务市场额度不足 |
602104 | httpdns服务商返回结果为空 |
602105 | 调用httpdns服务商结果超时 |
602106 | httpdns服务商返回数据不合法 |
602107 | httpdns域名解析结果为空 |
602108 | 不支持的httpdns服务商id |
为了保护微信客户端的安全,小程序使用的移动解析服务需要通过微信侧安全认证,认证后可在微信服务平台上架。
微信侧欢迎更多服务商为小程序提供移动解析服务。申请接入按照以下模板发送邮件,我们会有专人与您联系。
收件人:servicemarket@tencent.com 主题:【上架服务平台】XXX(服务商)申请上架HttpDNS服务 正文:需要写明服务商的基本资料,包括不仅限于服务商名称、业务范围、技术证书、合作意向、联系方式等