Skip to content

小程序版halo,利用halo移动api开发的一款小程序端,坚持简约风格

License

Notifications You must be signed in to change notification settings

PawNzZi/MiniHalo

Repository files navigation

演示

minihalo

minihalo是根据halo博客移动api开发的小程序。

halo博客系统部署后只能在web端使用,而halo的强大之处不仅用于写博客,有些业务在web端不是很方便,可以通过api实现小程序端,用户在小程序端就可以更好的增加用户粘性

使用指南

  1. 将本项目下载或clone到本地,用微信小程序开发工具打开,打开时选择小程序(非小游戏),选择云函数开发,填写自己的appid。
git clone https@github.com:PawNzZi/minihalo.git
  1. 打开app.js文件找到下面代码块,将xxx替换为halo后台设置的签名,访问api时需要鉴权
globalData: {AUTHORIZATIONS: 'xxxxxxx'}
  1. 部署好云函数后到app.js文件找到下面代码块,将xxx替换为自己云函数的环境ID
 wx.cloud.init({
    env: 'xxx',
    traceUser: true,
  })
  1. 打开app.js文件找到uploadThumb函数,将xxx替换为halo域名,上传附件使用
wx.uploadFile({
      url: 'https://xxx/api/admin/attachments/upload',
     filePath: tempFilePaths[0],
     name: 'file',
    header: {
    'admin-authorization': admin.access_token
  },
  1. 打开utils/api.js文件找到下面代码块,将xxxx替换为你的halo域名,halo域名必须是https协议
const https = 'https://xxx.xxx.xxxx
  1. 打开pages/user/user.wxml文件找到下面代码块,将图片地址替换为自己的,该图片为个人中心用户头像的背景
<view class="user-card" style="background-image: url('http://cdn.lingyikz.cn/1user_backgroud.jpg')"></view>
  1. 在page目录下的所有js文件里,找到以下代码,将相关信息替换成自己的
onShareAppMessage:function(){
    return App.shareAppMessage('13号档案馆', '../../img/share_pictrue.jpg', '/pages/index/index');
  };
onShareTimeline:function(){
    return App.sharePyqMessage('13号档案馆','../../img/share_pictrue.jpg','../../img/share_pictrue.jpg','/pages/index/index');
  };
  1. 打开微信小程序后台,开发==>开发管理==>开发设置==>服务器域名将自己的halo域名添加到request合法域名中

  2. 继续在小程序后台,设置==>第三方设置==>插件管理,添加html2wxml富文本组件

  3. 登陆halo后台,添加分类和标签

  4. 登陆halo后台,打开评论功能

  5. 个人中心里的友链,我是利用halo的友链实现的,正常进入halo后台新增友链, 网站名称:填写成你自己的(小程序名称) 分组:miniprogram 描述:{"appId":"小程序appid","path":"小程序跳转路径"}

注意:

  • 首页banner后的背景色和状态栏颜色是根据banner图主色动态设置的,如想使用该功能,需满足两个条件;
  1. 图片资源必须是https协议,例如我用的是七牛云存储图片,七牛云的域名设置成https协议;
  2. 将该域名添加至小程序后台的dowmload合法域名中,参考上面第5步;
  • 如不想使用该功能,可注释掉相关代码;
  • 项目中img目录是用来存放静态资源的,包括tabbar和空状态等,可根据自己的需要做替换;
  • 代码中基本上都写有注释,有条件的基友可根据自己需求自行修改;
  • 使用过程有任何疑问和bug可添加QQ245920672或在issue中反馈;
  • 目前实现了基本的功能,后续会添加新的需求和管理员操作。
  • 在开发工具中搜索:[email protected],搜索到的全部修改为自己的邮箱或特定邮箱(该作用主要用来区分评论来自web还是小程序)

主要特点

  • 首页banner后的背景色动态设置;
  • 坚持简约风格,简单粗暴,不喜欢花里胡哨,功能紊乱;
  • 用户可对文章进行评论和喜欢;
  • 评论数据与web打通,web评论可在小程序查看,并显示该评论来自web、小程序或管理员;
  • 可回复他人的评论;
  • 实现小程序端管理,可新增,编辑,删除分类-标签-友链-评论-文章等功能
  • 评论调用云函数利用腾讯的接口判断敏感词
  • 调用云函数判断该用户是否为管理员(不是管理员个人中心不出现登陆入口)
  • 管理员发布文章调用云函数访问第三方api检测文章是否有敏感词
  • 管理员发布文章利用pinyin-pro自动将标题转换成拼音,并设置成slug,与halo后台发布文章时一样

感谢

  • halo :一款优秀的开源博客发布应用。
  • vant-weapp :轻量、可靠的小程序 UI 组件库。
  • html2wxml :用于微信小程序的HTML和Markdown格式的富文本渲染组件,支持代码高亮
  • mini-add-tips :用于提示用户首次进入小程序时,点击右上角菜单进行【添加到我的小程序】操作
  • wxTimer :微信小程序中的定时器(用于倒计时)
  • pinyin-pro :中文转拼音、拼音音调、拼音声母、拼音韵母、多音字拼音、拼音首字母

About

小程序版halo,利用halo移动api开发的一款小程序端,坚持简约风格

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published