您现在的位置是:首页 > 学无止境 > web前端web前端
PbootCMS微信小程序API的封装使用教程
AndyGuo2020-04-10 09:04:41【web前端】3501人已围观
简介如何用PbootCMS做微信小程序呢,看完这篇文章你也可以学会。
第一步:准备md5加密文件
PbootCMS的签名参数signature是经过双层md5加密的,当然如果后台WebAPI没有开启强制认证的,这一步可以跳过。
第二步:封装API请求方法
//声明一个API请求函数 function api_request(url, method, parm){ var apiurl = 'https://www.pbootcms.com/api.php'; //域名 + api.php var appid = 'wx12345678910'; //后台WebAPI中设置的AppID var appsecret = '12334356465765867878943'; //后台WebAPI中设置的API认证密钥 var timestamp = Date.parse(new Date()); timestamp = timestamp / 1000; //获取当前时间戳 var signature = md5.hex_md5(md5.hex_md5(appid + appsecret + timestamp)); //构建signature var data = { //因为搜索、留言和表单需要用到POST方法,要通过data传递参数,所以先声明data对象,方便后面添加 appid: appid, timestamp: timestamp, signature: signature, }; //根据请求方法构建Header if (method == 'POST') { //POST方法,设置请求头部 var header = { 'Content-Type': 'application/x-www-form-urlencoded; charset=utf-8' }; //添加POST参数到data for (var i in parm) { data[i] = parm[i]; } } else { //GET方法,设置请求头部 method = 'GET'; var header = { 'Content-Type': 'application/json' }; } //通过promise返回数据 var promise = new Promise(function(resolve,reject){ //小程序自带的wx.request请求 wx.request({ method: method, url: apiurl + url, header: header, data: data, //请求成功 success: function(res){ var api_data = res.data; if (api_data.code != 1 && api_data.code != 0){ reject({ error: '数据请求失败,请稍后重试', code: 500 }); return; } else { resolve(api_data); } } }) }) //返回数据 return promise; }
第三步:封装官方API模块
//官方Api模块进行封装 module.exports = { //获取公司信息 companyInfos: function(){ var url = '/cms/company'; return api_request(url); }, //获取单个公司信息 companyInfo: function(name){ var url = '/cms/company/name/' + name; return api_request(url); }, //获取网站信息 siteInfos: function(){ var url = '/cms/site'; return api_request(url); }, //获取单个网站信息 siteInfo: function(name){ var url = '/cms/site/name/' + name; return api_request(name); }, //获取自定义标签 getLabels: function(){ var url = '/cms/label'; return api_request(url); }, //获取单个自定义标签 getLabel: function(){ var url = '/cms/label/name/' + name; return api_request(url); }, //获取幻灯片 getSlide: function(gid,num){ var url = '/cms/slide/gid/' + gid + '/num/' + num; return api_request(url); }, //获取友情链接 getLinks: function(gid,num){ var url = '/cms/link/gid/' + gid + '/num/' + num; return api_request(url); }, //获取栏目列表 getNavs: function(){ var url = '/cms/nav'; return api_request(url); }, //获取指定栏目列表 getNav: function(scode){ var url = '/cms/nav/scode/' + scode; return api_request(url); }, //获取当前栏目 getCurrentCat: function(scode){ var url = '/cms/sort/scode/' + scode; return api_request(url); }, //获取内容列表 getList: function(scode,num,order){ if( ( num != '' ) && !order ){ var url = '/list/' + scode + '/num/' + num; } else if( !num && ( order != '' ) ){ var url = '/list/' + scode + '/order/' + order; } else if ( (num != '') && (order != '') ){ var url = '/list/' + scode + '/num/' + num + '/order/' + order; } else { var url = '/list/' + scode; } return api_request(url); }, //获取内容列表第*页 getListPaged: function (scode, paged, num, order) { if ((num != '') && (order == '')) { var url = '/list/' + scode + '/num/' + num + '/page/' + paged; } else if ((num == '') && (order != '')) { var url = '/list/' + scode + '/order/' + order + '/page/' + paged; } else if ((num != '') && (order != '')) { var url = '/list/' + scode + '/num/' + num + '/order/' + order + '/page/' + paged; } else { var url = '/list/' + scode + '/page/' + paged; } return api_request(url); }, //获取指定内容 getContent: function(id){ var url = '/content/' + id; return api_request(url); }, //获取指定内容 getContent: function(scode){ var url = '/about/' + scode; return api_request(url); }, //获取指定内容多图 getContent_pics: function(id){ var url = '/cms/pics/id/' + id; return api_request(url); }, //获取搜索结果 getSearchResault: function(parm,num,order){ if ((num != '') && (order == '')) { var url = '/cms/search/' + 'num/' + num; } else if ((num == '') && (order != '')) { var url = '/cms/search/' + 'oder/' + order; } else if ((num != '') && (order != '')) { var url = '/cms/search/num/' + num + '/order/' + order; } else { var url = '/cms/search/'; } return api_request(url, 'POST', parm); }, //提交留言 addMessage: function(parm){ var url = '/cms/addmsg'; return api_request(url, 'POST', parm); }, //获取留言内容 getMessage: function(num){ var url = '/cms/msg/num/' + num; return api_request(url); }, //获取留言内容第*页 getMessagePaged: function(num,paged){ var url = '/cms/msg/num/' + num + '/page/' + paged; return api_request(url); }, //提交表单 addForm: function(fcode,parm){ var url = '/cms/addform/fcode/' + fcode; return api_request(url, 'POST', parm); }, //获取表单内容 getForm: function(fcode){ var url = '/cms/form/fcode/' + fcode; return api_request(url); }, //获取表单内容第*页 getFormPaged: function(fcode,num,paged){ var url = '/cms/form/fcode/' + fcode + '/num/' + num + '/page/' + paged; return api_request(url); }, }
本文转载自:舒彬琪博客,原文链接:http://cnsbq.com/pbootcms/314.html
- 版权申明:此文如未标注转载均为本站原创,自由转载请表明出处《小郭博客》。
- 本文网址:http://www.d163.net/html/web2/40.html
- 上篇文章:js刷新页面方法大全
- 下篇文章:js获取单选按钮的数据
PbootCMS标签大全
最新发表
标签云 更多
-
SAP(1)
奥运会(1)
短视频(1)
杨倩(1)
提拉米苏(1)
大家财险机动车辆保险(1)
王一博(1)
肖战(1)
苏炳添(1)
刘德华(1)
小鹏汽车(1)
高考(4)
阿里云(1)
HR(1)
邓伦(1)
李莎(1)
杜淳(2)
PHP教程(7)
陈好(1)
playhouse(1)
fopen(1)
山村疯狂(1)
第二书包(0)
69乐园(1)
牡丹江民心网(1)
授课到天亮(1)
天天综合(2)
好人岛(1)
符印巨树(1)
男子汉图库(1)
采花小绵羊(1)
涡卷花束(1)
一方嘉通(1)
李心草(2)
半藏森林不带套(2)
王镁幼(2)
嫦娥五号(3)
周冬雨(1)
黄晓明(1)
金鸡奖获奖名单(3)
网页计数器(2)
成都大学(1)
中科创星(1)
马拉多纳(4)
世界互联网大会(2)
porndao(1)
web前端(6)
网站优化(6)
cookie(2)
session(2)
301重定向(1)
headerlocation(1)
百度站内搜索(1)
爱奇艺(2)
爱奇艺弹幕开关不见了(1)
制作网页教程(4)
刘诗昆(1)
react(1)
linear-gradient(1)
旅游网站建设方案(1)
我爱自学网(2)
诺贝尔(1)
笔记(1)
居里夫人(1)
郭德纲(1)
杨紫(2)
蚂蚁金服上市时间(3)
爱琴海(1)
李连杰(1)
陈佩斯(1)
梁静茹(2)
个人网站模板(0)
个人网站制作(3)
个人网站(3)
网页制作(10)
帝国CMS(6)
百度地图API(2)
伪静态(2)
jizhicms(6)
1024(3)
去除bom(1)
Git(2)
中国人民志愿军(2)
麒麟9000(2)
Mate40(2)
新冠病毒(15)
摩天轮(1)
布达佩斯(1)
div居中(2)
新冠疫苗最新消息(12)
新冠疫苗(6)
昆仑饭店(2)
赵丽颖(6)
正面照(2)
石原里美(2)
店员(1)
理发(2)
十几万(1)
伊能静(1)
京东(4)