乐趣区

关于ide:Charles-应用通过-Charles-分析社区话题功能

背景

App 目前没有经营疏导工具对用户内容进行正当疏导,须要减少话题经营工具。提供 App 社区内容品质和每天 UGC 量级。

参考

社区帖子增加标签是一个很罕用的性能,大部分的社区 App 都有实现,诸如 微博,豆瓣,Oppo 社区,现实,蔚来。真正在进入此需要之前,最好理解下相干平台的产品。

以上别离是 豆瓣、蔚来、Oppo 社区、现实汽车 的 Tag 展现计划。

  • Tag 能够反对一个或者多个

开始抓包 剖析接口

前面所贴出的 返回后果针对 Topic 局部 JSON,其余局部省略。

豆瓣

豆瓣列表 展现

{
    "topic_label_bg_color":"#F7F7F7",
    "topic_label_bg_img":"","name":" 读书时写的乏味批注 ","topic_icon_large":"",
    "url":"https://www.douban.com/gallery/topic/164512/",
    "uri":"douban://douban.com/gallery/topic/164512",
    "topic_icon":"","topic_label_hashtag_color":"#5DC66F","topic_label_text_color":"#39A94C","type":"gallery_topic","id":"164512"
}

豆瓣主题详情

{
    "subscription_count": 1267,
    "creator": null,
    "is_subscribed": false,
    "invite_type": "","screenshot_title":" 分享海报 ","screenshot_url":"douban://partial.douban.com/screenshot/gallery/topic/164512/_content","guests": [],"card_subtitle":"88 篇内容・ 164.1 万次浏览 ","screenshot_type":"rexxar","id":"164512","is_closed": false,"focused_subject": null,"topic_label_bg_color":"#F7F7F7","topic_label_bg_img":"",
    "has_create_button": true,
    "group": null,
    "topic_tabs": [],
    "post_count": 88,
    "name": "读书时写的乏味批注",
    "label": "","topic_label_hashtag_color":"#5DC66F","ad_monitor_urls": [],"is_ad": false,"unpublic_reason":"",
    "participant_count": 92,
    "tags": [],
    "subject_card": null,
    "cover_url": "","introduction":" 明天重翻了我从前看的书,对于本人写的批注感到好笑,尽管很多是无厘头的碎碎念,但也很乏味不是么?让我看看你们写的吧,一起分享这高兴!","content_type": 6,"is_public": true,"topic_label_text_color":"#39A94C","sharing_url":"https://www.douban.com/doubanapp/dispatch?uri=/gallery/topic/164512/","wechat_timeline_share":"url","topic_icon_large":"",
    "click_track_urls": [],
    "uri": "douban://douban.com/gallery/topic/164512",
    "create_button_text": "","topic_icon":"",
    "mask_color": "","mask_type":""
}

外围信息:类型、跳转地址、名称、文字背景色、文字色彩、文字背景图片、图标,形容,文章公布数

蔚来

帖子列表

{
    "name": "EC6 提车季",
    "topic_id": "20872"
}

帖子详情

{
    "topic_id": 20872,
    "topic_name": "EC6 提车季",
    "img_url": "https://cdn-app.nio.com/user/2020/9/24/419faa45-35eb-412b-86c1-d4a3cfd33a36.jpeg",
    "summary": "2020 年 12 月 31 日前 (含) 参加话题互动,分享你的提车作业或用车体验,每月抽选 10 位用户各取得 500 积分处分",
    "create_user_id": "660135565",
    "create_type": 1,
    "sort_id": 77,
    "ugc_count": 256,
    "attend_user_count": 12640,
    "new_hot_tag": 0,
    "create_time": 1600962984,
    "update_time": 1600997614,
}

蔚来的 Tag 显示逻辑是,在文章列表页 只是显示比较简单的 Topic 名称和 ID,只是作为展现应用。当进入 Topic 专题页时 拉取以后 Topic 详细信息。

外围信息:名称,图片、形容、文章 UGC 数量,参加人数。

现实

帖子列表(右)

{
    "productId": 95830,
    "name": "有现实的假期",
    "browseNum": 0,
    "participantsNum": 0,
    "contentNum": 0,
    "type": 1,
    "topicMark": 1
}

帖子详情(左)

{
    "success": true,
    "code": 0,
    "data": {
        "productId": 95830,
        "name": "有现实的假期",
        "type": 1,
        "description": "当国庆节遇上中秋节,就迎来了疫情之后的第一个黄金周长假,在家憋了大半年,这次长假你筹备好往年的“报复性”旅行了吗?连忙来分享你的自驾旅途,晒路线、晒美食、晒配备... 要害是还有机会赢 SWITCH 游戏机!",
        "image": "https://p.ampmake.com/aisp/community/aisp/community/6ece59aa-7604-4f52-bcc3-2577f9a9f678.jpg",
        "imageRes": "1600*900",
        "browseNum": 650,
        "participantsNum": 164,
        "contentNum": 273,
        "router": "https://www.lixiang.com/community/detail/topic/95830.html",
        "createdAt": 1601012653000,
        "topicMark": 1
    },
    "msg": "胜利"
}

在进入帖子详情时,会拉取 Tag 详细信息。随后获取以后 Tag 下的帖子。从返回后果 router 字段 能够看出 现实汽车 主题实现是通过 H5 进行实现的。

外围信息: H5,浏览数,公布数,内容,类型,形容,图片,图片大小

Oppo 社区

帖子列表

[{
    "id": 970,
    "name": "低头,看树!"
}]

帖子详情

{
    "id":941,
    "name":"我怎么这么难看",
    "weight":1029,
    "status":1,
    "related":0,
    "perm":1,
    "style":0,
    "type":"","guide":" 收回你的自拍吧!","description":" 收回你的自拍吧!","small_img":"https://imgfs.oppo.cn/uploads/topic/2020/07/31/17315884601.jpg","pc_img":"https://imgfs.oppo.cn/uploads/topic/2020/07/31/17320924401.jpg","big_img":"https://imgfs.oppo.cn/uploads/topic/2020/07/31/17320396101.jpg","insert_time":1596187981,"insert_by":15122500992,"compere_ids":"",
    "category_id":1,
    "category_name":"人像",
    "group_id":"","related_topic":"",
    "reply":"1.2 万",
    "follower":64,
    "thread":"1.3 万",
    "read":"33.3 万",
    "is_follow":0,
    "username":[]}

抓包发现,Oppo 社区 局部接口 采纳的是 protobuf 协定。不太好抓。对应 的网页 是 Json 的模式

要害信息: H5,名称,图片,地址,类型,回复量,参加量,读取,状态。

话题抉择页

能够看出大抵的都差不多可能须要关注的几个点

  • 话题有热门非热门的辨别
  • 话题具备类型
性能 Oppo 社区 蔚来 现实汽车 豆瓣
名称 ✔️ ✔️ ✔️ ✔️
形容 ✔️ ✔️ ✔️ ✔️
H5 ✔️ ✔️ ✔️
状态 ✔️
话题列表展现参加数 ✔️ ✔️ ✔️ ✔️
浏览 ✔️ ✔️ ✔️ ✔️
探讨 ✔️ ✔️ ✔️ ✔️
Label 能够配置 ✔️ ✔️ ✔️ ✔️
图片 ✔️ ✔️ ✔️ ✔️

设计

在咱们社区话题的需要中,还有另外一个子需要就是 话题详情中的文章能够反对独自的排序配置。

因为咱们这边社区的主数据库是 mongodb,所以这里预留了一个 extend 字段 作为扩大字段,用来应答各种需要。比方针对以后 Topic 下的文章反对自定义排序,那么咱们就能够在 extend 对象中减少 sort 字段

本文由博客群发一文多发等经营工具平台 OpenWrite 公布

退出移动版