一个用Go写的微信模板消息推送服务

栏目: Go · 发布时间: 7年前

内容简介:一个用Go写的微信模板消息推送服务

项目已经在Github开源,还没有完全地完善,但是用是没问题的。

求各位大神的star啊,这是我的第一个比较完整的 Go 程序。( ^__^ )

怎么用?

第一步当然是go get

  • go get github.com/hundredlee/wechat_pusher.git
  • 当然你也可以直接clone整个项目,直接导入IDE中跑一下试试

项目结构

├── README.md
├── config
│   └── config.go
├── config.conf.example
├── glide.lock
├── glide.yaml
├── main.go.example
├── models
│   ├── message.go
│   ├── task.go
│   └── token.go
├── statics
│   └── global.go
├── utils
│   ├── access_token.go
│   └── push.go
└── vendor

配置文件

  • 我们可以看到根目录有一个config.conf.example,重命名为config.conf即可
  • 内容如下:
[WeChat]
APPID=
SECRET=
TOKEN=
TEMPLATE=
  • 具体怎么填,我就不说了。这是接触过微信开发的童鞋都知道的东西。

模板配置怎么配置

  • 我们看看models文件夹里面有message.go文件,里面其实就是模板的格式。
  • 具体怎么用,看看main.go.example文件里面的示例。
package main

import (
	"fmt"
	"github.com/hundredlee/wechat_pusher/models"
	"github.com/hundredlee/wechat_pusher/utils"
	"runtime"
)

func main() {

	runtime.GOMAXPROCS(runtime.NumCPU())
	var tasks []models.Task
	tasks = make([]models.Task, 100)
	mess := models.Message{
		ToUser: "openid",
		TemplateId: "templateId",
		Url: "http://baidu.com",
		Data: models.Data{
			First: models.Raw{"xxx", "#173177"},
			Subject: models.Raw{"xxx", "#173177"},
			Sender: models.Raw{"xxx", "#173177"},
			Remark: models.Raw{"xxx", "#173177"}}}
	task := models.Task{Message: mess}
	for i := 0; i < 100; i++ {
		task.Message.Data.First.Value = fmt.Sprintf("%d", i)
		tasks[i] = task
	}

	utils.NewPush(tasks).SetRetries(4).SetBufferNum(10).Run()
}

Run

  • 很简单,当你组装好所有的task以后,直接运行一句话就可以了。
  • utils.NewPush(tasks).SetRetries(4).SetBufferNum(10).Run()

打算?

  • 目前还是比较简单的推送,然后日志相对来说比较完整。但是缺少了计划任务功能。大家可以star一下,等我更新计划任务的功能。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS基础教程

CSS基础教程

Simon Collison / 刘志忠 等 / 人民邮电出版社 / 2007 / 49.00元

《CSS 基础教程》是优秀的CSS 入门书,重点讲述了如何使用CSS 实现基于Web 标准的网站开发,实现网站内容和表现相分离。《CSS 基础教程》包括两部分。第一部分介绍了CSS 的基础知识和基本概念,再利用CSS 分别对网页创建中的一些基本元素加上样式,包括:文本、图像、列表、链接、表格、表单等。第二部分主要讨论了基于CSS 来实现网页基本布局的相关概念与技术,包括浮动、流体布局等。《CSS ......一起来看看 《CSS基础教程》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具