您现在的位置是:首页 > 教程 > pbootcms教程pbootcms教程
pbootcms怎么做微信小程序
蒋进如2024-12-06 23:23:08pbootcms教程已有人查阅
导读如何用PbootCMS做微信小程序呢,看完这篇文章你也可以学会。第一步:准备md5加密文件
PbootCMS的签名参数signature是经过双层md5加密的,当然如果后台WebAPI没有开启强制认证的,这一步可以跳过。
如何用PbootCMS做微信小程序呢,看完这篇文章你也可以学会。
第一步:准备md5加密文件
PbootCMS的签名参数signature是经过双层md5加密的,当然如果后台WebAPI没有开启强制认证的,这一步可以跳过。
第二步:封装API请求方法
第一步:准备md5加密文件
PbootCMS的签名参数signature是经过双层md5加密的,当然如果后台WebAPI没有开启强制认证的,这一步可以跳过。
第二步:封装API请求方法
//声明一个API请求函数
function api_request(url, method, parm){
var apiurl = 'https:// .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- -form-urlencoded; charset=utf-8' };
//添加POST参数到data
for (var i in parm) {
data = parm;
}
} 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);
},
}
本文标签:
很赞哦! ()
上一篇:pbootcms菜单二次开发教程
下一篇:pbootcms任意代码执行分析
相关文章
随机图文
-
pbootcms栏目/列表/幻灯片顺序从第N个开始的写法
PBOOTCMS栏目/列表/幻灯片顺序从第N个开始[list:i operate=+1][nav:i operate=+1][slide:i operate=+1] -
pbootcms模板怎么安装与授权
1、系统自带完整后台以及模板,默认采用SqlITe数据库,不需要做导入和配置操作,放入PHP(5.3+)空间即可直接使用, -
pbootcmsV2.0.6新增的个人扩展标签定制每日一图的方法
自PbootCmsV2.0.6开始,pbootcms支持自定义标签,且升级不被覆盖。妈妈再也不用担心我的代码升级被覆盖啦。于是就想到用这个功能定制一个每日一图 -
pbootcms获取结果页面关键词和tags值的方法
如果您的搜索结果页面地址后缀为keyWord=三角形那么获取关键词方式为 {$get.keyword}该标签可用于搜索列表页面获取搜索关键词的值时候使用,非常方便,可以搭配分页条的总数据行数属性({page:rows})
留言与评论 (共有 条评论) |