公众号会话控制和获取聊天记录

洛塔服务号回复013获取代码。

功能说明

会话控制:此接口在客服和用户之间创建一个会话,如果该客服和用户会话已存在,则直接返回0。指定的客服帐号必须已经绑定微信号且在线。

获取聊天记录:此接口返回的聊天记录中,对于图片、语音、视频,分别展示成文本格式的[image]、[voice]、[video]。对于较可能包含重要信息的图片消息,后续将提供图片拉取URL,近期将上线。

准备工作

公众号后台设置ip白名单

创建会话

创建会话中,客服账号格式为客服账号@公众号的微信号。比如我的客服账号是lootaa,公众号微信号是lootaayun,则请求参数为lootaa@lootaayun。
需要先从网页登录客服,然后创建会话,就能看到对应的会话消息了。为了方便后面测试关闭会话,我创建了两个会话。

		// 先获取access_token,这部分正式环境需要配置定时获取,每天2000次调用限制
		String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + APPID + "&secret=" + SECRET;
		String result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);
		String accessToken = JSON.parseObject(result).getString("access_token");
		
		// 创建会话
		url = "https://api.weixin.qq.com/customservice/kfsession/create?access_token=" + accessToken;
		JSONObject param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6iaFJq6SISTVwHS5lkb9Pb8");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);
		// 再创建一个会话,用来测试关闭会话
		param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6tQGQMqM-WuHMaCiR5AkY2Q");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);

关闭会话

将上面创建的两个会话关闭掉一个

		// 关闭会话
		url = "https://api.weixin.qq.com/customservice/kfsession/close?access_token=" + accessToken;
		param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6tQGQMqM-WuHMaCiR5AkY2Q");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);

获取客户会话状态

如果客服不繁忙,这个返回的一般都是状态0

		// 获取客户会话状态
		url = "https://api.weixin.qq.com/customservice/kfsession/getsession?openid=ohUHp6iaFJq6SISTVwHS5lkb9Pb8&access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);

获取客服会话列表

如果关闭掉会话,这个接口就获取不到了。

		// 获取客服会话列表
		url = "https://api.weixin.qq.com/customservice/kfsession/getsessionlist?kf_account=lootaa@lootaayun&access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);

获取未接入的会话

不容易测试出来数据,除非客服繁忙

		// 获取未接入会话列表
		url = "https://api.weixin.qq.com/customservice/kfsession/getwaitcase?access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);

获取聊天记录

每次查询时段不能超过24小时。
每次获取条数,最多10000条。

		// 获取聊天记录
		url = "https://api.weixin.qq.com/customservice/msgrecord/getmsglist?access_token=" + accessToken;
		param = new JSONObject();
		param.put("starttime", System.currentTimeMillis()/1000-24*3600*3);
		param.put("endtime", System.currentTimeMillis()/1000-24*3600*2);
		param.put("msgid", 1);
		param.put("number", 10000);
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);

全部代码

package com.lootaa.wechat;

import org.jsoup.Connection.Method;
import org.jsoup.Jsoup;
import org.springframework.web.bind.annotation.RestController;

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;

/**
 * 客服消息-会话控制和获取聊天记录
 * 前置条件:公众号后台设置ip白名单
 */
@RestController
public class Test013 {

	public static final String APPID = "wx276049d6a7551dca";
	public static final String SECRET = "cbe109fdf6f399bd72ed3a4afafa21b1";
	
	/**
	 * 完整项目源码可关注公众号"lootaayun"(洛塔),回复013获取
	 */
	public static void main(String[] args) throws Exception {
		// 先获取access_token,这部分正式环境需要配置定时获取,每天2000次调用限制
		String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + APPID + "&secret=" + SECRET;
		String result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);
		String accessToken = JSON.parseObject(result).getString("access_token");
		
		// 创建会话
		url = "https://api.weixin.qq.com/customservice/kfsession/create?access_token=" + accessToken;
		JSONObject param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6iaFJq6SISTVwHS5lkb9Pb8");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);
		// 再创建一个会话,用来测试关闭会话
		param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6tQGQMqM-WuHMaCiR5AkY2Q");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);
		
		// 关闭会话
		url = "https://api.weixin.qq.com/customservice/kfsession/close?access_token=" + accessToken;
		param = new JSONObject();
		param.put("kf_account", "lootaa@lootaayun");
		param.put("openid", "ohUHp6tQGQMqM-WuHMaCiR5AkY2Q");
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);
		
		// 获取客户会话状态
		url = "https://api.weixin.qq.com/customservice/kfsession/getsession?openid=ohUHp6iaFJq6SISTVwHS5lkb9Pb8&access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);
		
		// 获取客服会话列表
		url = "https://api.weixin.qq.com/customservice/kfsession/getsessionlist?kf_account=lootaa@lootaayun&access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);
		
		// 获取未接入会话列表
		url = "https://api.weixin.qq.com/customservice/kfsession/getwaitcase?access_token=" + accessToken;
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.GET).execute().body();
		System.out.println(result);
		
		// 获取聊天记录
		url = "https://api.weixin.qq.com/customservice/msgrecord/getmsglist?access_token=" + accessToken;
		param = new JSONObject();
		param.put("starttime", System.currentTimeMillis()/1000-24*3600*3);
		param.put("endtime", System.currentTimeMillis()/1000-24*3600*2);
		param.put("msgid", 1);
		param.put("number", 10000);
		result = Jsoup.connect(url).ignoreContentType(true).method(Method.POST).requestBody(param.toString()).execute().body();
		System.out.println(result);
	}
	
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Cookies 是一种在客户端(通常是浏览器)存储信息的技术,用于在不同页面和浏览器会话之间保持持久状态。Cookies 可以用于会话控制,这是一种控制用户在应用程序中访问和执行操作的技术。 会话控制是 Web 应用程序中的一项关键技术,用于跟踪用户在应用程序中的活动和状态。会话控制技术允许应用程序跟踪用户访问的页面和执行的操作,并根据用户的身份和权限控制访问受限资源。 在 Cookies 中存储会话信息的最常见方法是将会话 ID 存储在 Cookies 中。当用户首次访问应用程序时,应用程序会创建一个唯一的会话 ID,并将其存储在 Cookies 中。在用户的后续请求中,应用程序将会话 ID 从 Cookies 中读取,并使用它来检索用户的会话数据。 以下是一个使用 Cookies 实现会话控制的示例: ``` <?php session_start(); // 检查用户是否已经登录 if (!isset($_SESSION['username'])) { // 用户未登录,跳转到登录页面 header('Location: login.php'); exit; } // 用户已经登录,显示欢迎信息 echo 'Welcome, ' . $_SESSION['username'] . '!'; ?> ``` 在上面的示例中,session_start() 函数用于启动会话。如果用户未登录,代码将重定向到登录页面。如果用户已登录,代码将显示欢迎信息。 要使用 Cookies 实现会话控制,需要确保以下几点: 1. 应用程序必须对会话 ID 进行加密和解密,以确保安全性。 2. 应用程序必须设置会话超时时间,以确保会话不会永久保留。 3. 应用程序必须使用安全的 Cookies,以确保 Cookies 不会被劫持或篡改。 总之,Cookies 是实现会话控制的一种常见技术,可以帮助应用程序跟踪用户在应用程序中的活动和状态,并根据用户的身份和权限控制访问受限资源。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lootaa

你的鼓励是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值