全部产品
存储与CDN 数据库 安全 应用服务 数加·人工智能 数加·大数据基础服务 互联网中间件 视频服务 阿里云办公 培训与认证 物联网
消息队列 MQ

搜索指定发布信息

更新时间:2017-06-07 13:26:11

本文介绍 OnsPublishSearch 接口,调用该接口根据搜索条件查询相关的发布关系。

1. 使用场景

OnsPublishSearch 接口一般用在用户账号下 PID 太多无法同时展现时,根据关键字搜索符合条件的发布关系,展现的数据格式和 OnsPublishGet 接口一致。

2. 请求参数列表

名称 类型 是否必须 描述
OnsRegionId String 当前查询 MQ 所在区域,可以通过 OnsRegionList 方法获取
OnsPlatform String 该请求来源,默认是从 POP 平台
PreventCache Long 用于 CSRF 校验,设置为系统当前时间即可
Search String 搜索的关键词,可以是 Topic 或者 PID

3. 返回参数列表

名称 类型 描述
RequestId String 为公共参数,每个请求独一无二
HelpUrl String 帮助链接
Data List(PublishInfoDo) 查询结果集合

PublishInfoDo数据结构

成员 类型 描述
id Long 该发布信息在数据库中的 ID
channelId Integer 该 Topic 所在区域 ID,0-ALIYUN,1-CLOUD,2,3,4
channelName String 该 Topic 所在区域名称,ALIYUN 代表阿里云,CLOUD 代表聚石塔,…
onsRegionId Long 该 Topic 所在区域 ID,就是 ONSRegionList 方法获取的内容
regionName String 该 Topic 所在区域名称
topic String Topic 名称
owner String Topic 所有者编号
relation Integer 所有关系编号1为持有者,2为可以发布,4为可以订阅,6为可以发布和订阅
relationName String 所有关系名称,例如持有者、可订阅、可发布、可发布订阅
status Integer 当前状态编号0-服务中
statusName String 当前状态别名,服务中
appkey Integer null
createTime Long 创建时间
updateTime Long 更新时间
remark String 备注,可以不填

4. 相关 API

  • OnsPublishDelete:删除发布关系
  • OnsPublishGet:查询发布关系
  • OnsPublishCreate:新建发布关系

5. 使用示例

调用示例

本示例以 PID_Mingduan 为搜索条件搜索 daily 区域下相关的 PID 信息,并将结果打印。

  1. public static void main(String []args) {
  2. String regionId = "cn-hangzhou";
  3. String accessKey = "XXXXXXXXXXXXXXXXX";
  4. String secretKey = "XXXXXXXXXXXXXXXXX";
  5. String endPointName ="cn-hangzhou";
  6. String productName ="Ons";
  7. String domain ="ons.cn-hangzhou.aliyuncs.com";
  8. /**
  9. *根据自己需要访问的区域选择Region,并设置对应的接入点
  10. */
  11. try {
  12. DefaultProfile.addEndpoint(endPointNameregionIdproductNamedomain);
  13. } catch (ClientException e) {
  14. e.printStackTrace();
  15. }
  16. IClientProfile profile= DefaultProfile.getProfile(regionIdaccessKeysecretKey);
  17. IAcsClient iAcsClient= new DefaultAcsClient(profile);
  18. OnsPublishSearchRequest request = new OnsPublishSearchRequest();
  19. /**
  20. *ONSRegionId是指你需要API访问MQ哪个区域的资源.
  21. *该值必须要根据OnsRegionList方法获取的列表来选择和配置,因为OnsRegionId是变动的,不能够写固定值
  22. */
  23. request.setOnsRegionId("daily");
  24. request.setPreventCache(System.currentTimeMillis());
  25. request.setAcceptFormat(FormatType.JSON);
  26. request.setSearch("PID_Mingduan");
  27. try {
  28. OnsPublishSearchResponse response=iAcsClient.getAcsResponse(request);
  29. List<OnsPublishSearchResponse.PublishInfoDo> publishInfoDoList =response.getData();
  30. for (OnsPublishSearchResponse.PublishInfoDo publishInfoDo:publishInfoDoList){
  31. System.out.println(publishInfoDo.getId()+" "+
  32. publishInfoDo.getChannelId()+" "+
  33. publishInfoDo.getChannelName()+" "+
  34. publishInfoDo.getOnsRegionId()+" "+
  35. publishInfoDo.getRegionName()+" "+
  36. publishInfoDo.getOwner()+" "+
  37. publishInfoDo.getProducerId()+" "+
  38. publishInfoDo.getTopic()+" "+
  39. publishInfoDo.getStatus()+" "+
  40. publishInfoDo.getStatusName()+" "+
  41. publishInfoDo.getCreateTime()+" "+
  42. publishInfoDo.getUpdateTime());
  43. }
  44. } catch (ServerException e) {
  45. e.printStackTrace();
  46. } catch (ClientException e) {
  47. e.printStackTrace();
  48. }
  49. }
本文导读目录