ke.qq.com url重构总结

一、重构的目的

1.url简化

过长的url不利于传播,比如输入框的字数限制导致分享的url被截断或分享内容无法提交。复制url文本时,短的url也可能使鼠标少拖动一段距离。

2.规范url

http://ke.qq.com/cgi-bin/courseDetail?course_id=36413 类似这个课程详情页的url,包含大、小字母、下划线和中划线。我们希望统一下划线做单词间分隔。

3.结构化,语义化

例如:http://ke.qq.com/tupu/3/course 这个链接表示图谱(学习导图)模块中,3号学习导图囊括的课程列表,这是url的结构。语义化:特性领域的一些词汇,"tupu"(图谱),“course”(课程)。为什么url中有汉语拼音,又有英文单词,那是因为大家觉得这样简洁,比较好懂。若把url中的图谱id“/3/”换成图谱名称"/android/",可能从语义上、搜索结果排名上会更好一些。

4.采用技术无关的url

提供动态内容服务时,像cgi-bin之类的单词不应该出现在url中。

说明:本次url重构主要是对直出页面做的。

二、url重构前、后的对应关系

重构前url

重构后URL

全部课程页

http://ke.qq.com/cgi-bin/courseList

http://ke.qq.com/course/list

搜索结果页

http://ke.qq.com/cgi-bin/courseList?word=android

http://ke.qq.com/course/list/android (2015.11.2发布)

课程详情页

http://ke.qq.com/cgi-bin/courseDetail?course_id=36413

http://ke.qq.com/course/36413

老师详情页

http://ke.qq.com/cgi-bin/teacher?tid=4140927368

http://ke.qq.com/teacher/4140927368

学团贴子列表页

http://ke.qq.com/cgi-bin/bbs/xbar_info?bid=226209

http://ke.qq.com/bbs/tuan/226209

学团帖子详情页

http://ke.qq.com/cgi-bin/bbs/posts/post_detail?bid=226209&pid=8097603-1435217065

http://ke.qq.com/bbs/topic/8097603-1435217065?bid=226209

图谱首页

http://ke.qq.com/cgi-bin/ke_graph?mapid=6

http://ke.qq.com/tupu/6

图谱的课程页

http://ke.qq.com/cgi-bin/ke_graph/courseList?mapid=6

http://ke.qq.com/tupu/6/course

H5所有页面

http://ke.qq.com/mobilev2/*.html

http://m.ke.qq.com/*.html

三、url重构需要做什么?

1.nginx转发规则

(1)索引擎收录了大量旧url,希望搜索引擎能快速地切换到新url,并且将页面的权重传递过去,所以用了301跳转,如下方图1所示。(2015.11.2发布) (2)希望url重构对CGI层透明,由接入层nginx完成新-旧地址的转换工作,如下方图2所示。

2.平台互转

教育的部分重点页面在PC端与移动端有2个不同版本的实现,如果用户使用手机浏览他人分享的PC课程详情页时,我们希望用户看到的是相应H5的课程详情页,反之亦然。处理这种不同平台url的对应关系叫平台互转。

pc url

移动端url

首页

http://ke.qq.com/

http://m.ke.qq.com/

课程详情页

http://ke.qq.com/course/36413

http://m.ke.qq.com/courseDetail.html?course_id=36413

全部课程页

http://ke.qq.com/course/list

http://m.ke.qq.com/courseList.html

老师详情页

http://ke.qq.com/teacher/4140927368

http://m.ke.qq.com/teacher.html?tid=4140927368

3.url提交

url重构后,出现了一批新地址,我们要将这批新地址及时地提交百度搜索引擎。

//提交百度
$(window).load(function () {
        $.getScript('http://push.zhanzhang.baidu.com/push.js');
});

4.路径上报

目前,用户访问路径上报是通过一份公共的配置管理的。 var KEY_MAP ={ '/cgi-bin/courseDetail': 'H', '/cgi-bin/courseList': 'K', ... }; 比如用户访问课程详情页http://ke.qq.com/cgi-bin/courseDetail?course_id=36413 ,那么在用户访问路径中会新增一个节点"H"与之对应。url变成http://ke.qq.com/course/36413 之后这个映射key也需要微调。

5.其他修改点

  • 后台代码对url的合法性检查
  • 页面内a标签url修改
  • 获取页面参数修改
  • 管理后台运营配置

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏数据小魔方

数据地图系列11|PowerMap!(上)

今天跟大家分享的是数据地图系列11——PowerMap! 这是一个excel的内置地理信息系统可视化工具,是微软PowerBI系列的四大工具之一。 在offic...

3794
来自专栏腾讯移动品质中心TMQ的专栏

快给你的用例做减法吧

前言 生活的智慧,有时不在于多,而在于少。 同理适用于测试用例的管理中。 一. 热身:数一数你的用例数 随着互联网时代节奏的日益加快,许多产品都会在版本迭代中对...

20510
来自专栏程序员笔记

钉钉机器人

2785
来自专栏腾讯移动品质中心TMQ的专栏

【腾讯TMQ】快给你的用例做减法吧

随着互联网时代节奏的日益加快,许多产品都会在版本迭代中对功能做加法,于是累计的测试用例似乎都无可避免地越来越多。从小编自己的经验,作为测试人员,最开始设计测试用...

2260
来自专栏何俊林

开发直播app中要了解的原理

前言:每个成功者多是站在巨人的肩膀上!在做直播开发时 碰到了很多问题,在收集了许多人博客的基础上做出来了成功的直播项目并做了整理 。本文来自OneTea,袁峥S...

28610
来自专栏惶心 - 技术博客

Web Icon 123 - 网页内图标的调用

之前 保罗 在使用 php 写他的第一个个人主页的时候,在他的群里提到了 Font-Awesome 这个项目。当时还是纯小白一个,啥也听不懂。直到后来,看了几篇...

77013
来自专栏磐创AI技术团队的专栏

DrQA基于维基百科数据的开放域问答机器人实战教程

【磐创AI导读】:本文主要向大家推荐一个开放域问答机器人的实战项目。欢迎大家点击上方蓝字关注我们的公众号:磐创AI。

651
来自专栏SEO

「因素」本地搜索引擎优化排名因素指南

28、非结构化引文的质量/权重(报纸文章,博客文章,政府网站,行业协会)(占1.65)

1282
来自专栏CDA数据分析师

学习路径:一文让你成为Tableau专家

原文链接:https://www.analyticsvidhya.com/learning-paths-data-science-business-analyt...

4867
来自专栏Albert陈凯

质疑Lambda架构

Google和Twitter刚发布它们综合实时流处理和批处理的Lambda架构,LinkedIn的Jay Kreps则对这种架构提出了质疑,指出实时处理和批处理...

3383

扫码关注云+社区