百度小程序-接入自然搜索-API提交Url-c#开发
开发百度小程序后,接下来,人们最想做的是让百度更多的录入自家内容。因为小程序资源被索引后,才可能在搜索结果中展现。
百度也提供了小程序的自然搜索提交入口。一共有两种方式:
第一种是用已有的H5网站资源替换,这种的录入速度应该非常快速,百度小程序平台将优先对 H5站点下的 TOP 流量 URL进行替换处理。
第二种提交新资源,接下来我们主要讲这第二种情况。
-----------------------------------------------------------------------------------------------------------
提交新资源又分为 “天级收录”和“周级收录”以及“自动同步”。资源提交的内容为小程序页面的path路径+参数。(官网地址入口 )天级提交一般48小时内有反馈,周级提交需要周级处理后反馈。
“天级收录”和“周级收录” 都又2种提交资源的方式,第一种是txt资源上传(Sitemap),整理小程序页面的所有Path路径+参数,每行一条记录。第二种方式为API提交。(官网教程入口)
根据官方提供的API文档说明,我们会知道如下几点:
第一:api的请求接口地址,用Post提交
https://openapi.baidu.com/rest/2.0/smartapp/access/submitsitemap/api
第二、参数说明
参数名 | 类型 | 是否必须 | 描述 | 示例 |
---|---|---|---|---|
access_token | string | 是 | 权限校验Token,获取方式见开发者服务权限说明 。 | |
type | int | 是 | 通过TYPE字段选择上传接口。 · 0:周级提交,一周左右生效; · 1:天级提交,2~3天生效; · 2:小时级提交,1小时内生效 | 0 |
url_list | string | 是 | 小程序path集合,多个path用逗号分隔。 · 天级提交配额根据提交活跃度和资源质量进行调节,具体以平台显示为准; · 周级提交配额每日上限为5W条,每次提交上限为3000条。 | /pages/index1?id=1,/pages/index2 |
第三,返回结果说明:
1、正确的结果:
{ "errno": 0, "msg": "success" }
2、若出现错误,则会返回错误提示:错误码说明:
错误码 | 错误描述 |
---|---|
0 | 成功 |
-1024 | 业务异常 |
500 | 对不起,服务器出错了,请稍候再试 |
2002 | 小程序不存在/选择的收录级别不合法/url数量不合法 |
30001 | 参数有误 |
30013 | 数量超上限 |
47005 | 文件上传失败 |
60005 | 尚未绑定熊掌ID,请先绑定熊掌ID |
官方提供几种语言的demo代码,比如 java,python,php,接下来我用c#代码实现相关的功能:
第1步:是获取access_token值:
string App_Key = "GUsp9GbxpfZNpnp1DjR1GrG2zGwGLhq2"; string App_Secret = "百度小程序的app_secret值"; string url = "https://openapi.baidu.com/oauth/2.0/token"; string param = $"grant_type=client_credentials&client_id={App_Key}&client_secret={App_Secret}&scope=smartapp_snsapi_base"; string ret = Utils.HttpPost(url, param); this.lblAccessToken.Text = ret;
Utils.HttpPost里的方法如下:
/// <summary> /// HTTP POST方式请求数据 /// </summary> /// <param name="url">URL.</param> /// <param name="param">POST的数据</param> /// <returns></returns> public static string HttpPost(string url, string param) { HttpWebRequest request = (HttpWebRequest)HttpWebRequest.Create(url); request.Method = "POST"; request.ContentType = "application/x-www-form-urlencoded"; request.Accept = "*/*"; request.Timeout = 15000; request.AllowAutoRedirect = false; StreamWriter requestStream = null; WebResponse response = null; string responseStr = null; try { requestStream = new StreamWriter(request.GetRequestStream()); requestStream.Write(param); requestStream.Close(); response = request.GetResponse(); if (response != null) { StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.UTF8); responseStr = reader.ReadToEnd(); reader.Close(); } } catch (Exception) { throw; } finally { request = null; requestStream = null; response = null; } return responseStr; }
access_token获取成功后,开始我们的url资源提交了。根据自家小程序页面path以及参数,提交相应的资源。多条记录用逗号隔开。
/// <summary> /// 每次发一批文章给百度小程序。 /// </summary> /// <param name="alist">alist的条数不要超过每次的上限。</param> /// <returns></returns> private string SendToBaiDu(int type, List<Model.article_id> alist) { string ret = ""; string ACCESS_TOKEN = "24.9ebc57a8f3b00375b8bb0ee59892ce52.2592000.1584192924.282335-18403980"; string postUrl = "https://openapi.baidu.com/rest/2.0/smartapp/access/submitsitemap/api"; string param = "access_token=" + ACCESS_TOKEN; StringBuilder sb = new StringBuilder(""); sb.Append("&type="+ type); sb.Append("&url_list="); for (int i = 0; i < alist.Count(); i++) { if (i != alist.Count() - 1) { sb.Append("pages/detail/detail?query=" + alist[i].id + ","); } else { sb.Append("pages/detail/detail?query=" + alist[i].id); } } param += sb.ToString(); ret = Utils.HttpPost(postUrl, param); return ret; }
到此就成功提交了,但是要记得每天的上限以及每次提交记录的上线。
花絮:
在开发调试过程中,遇到一个非常奇怪的现象,不管用什么方式提交资源,百度接口总会返回“47005文件上传失败”。一直以为是自己的代码问题,排查了好久没有解决。决定是官方论坛发帖求助,(入口),结果令人惊奇的发现,这个根据就不是我代码的bug,而是百度官方的接口返回有问题,等了大天,百度官方才修复了这个bug 。 所以,调用第3方接口,遇到诡异现象,有可能真的是第3方的问题。