如何定义好一个符合规范的url

描述

进公司没有多久遇到一个问题,定义的url会被大神吐槽说是很渣。之前从来没有注意这块,今天把我们团队的url规范分享给大家。

为什么需要URL规范化

1、网站URL和结构已经成为网站搜索引擎友好的最大基础性问题,网站URL 和结构问题,早发现早优化,越是往后放,最后就成了制约网站运营和产品开发的决定性因素。
2、无论是网站的可用性还是网站对搜索引擎的吸引力,清晰明了的浏览路径都是相当重要的,URL是统一资源定位,即每个网页的网址、路径。
3、浏览路径让网站的导航结构更清晰,可以更加平衡的分布网站权重。

反例(不规范的URL)

URL中多余的字符

1、子域名的URL中包含"www": "http://www.shuchao.cnblogs.com/"

2、含有默认端口: "http://www.cnblogs.com:80/shuchao/"

3、松散的URL: "http://www.chapters.indigo.ca/books/amazon-sucks-donkey-balls/9780470170779-item.html"

4、多余默认文件名index.html,default.aspx等:"http://www.cnblogs.com/shuchao/index.html"

5、文件路径中包含多余的"/":"http://www.cnblogs.com/shuchao//",多余的点修饰串:"x/y/z/http://www.cnblogs.com/a/b/http://www.cnblogs.com/../page.html"

6、查询串中多余的 ? (空查询串):http://www.cnblogs.com/shuchao?

7、多余的& 无用的查询变量:http://www.example.com/display?id=123&fake=fake

URL缺少字符串

缺少"/":"http://www.cnblogs.com/shuchao"
查询串缺少名称或者值:"http://www.example.com/display?id=" 或者 "http://www.example.com/display?=123"

其他不规范的URL

1、"http://shuchao.cnblogs.com/" 与 "http://www.cnblogs.com/shuchao/"其实是相同的内容即同一个资源,最好不要有两个urL

2、使用IP代替域名

3、大小写敏感("http://www.google.cn/Intl/zh-CN/about.html" 和"http://www.google.cn/intl/zh-CN/about.html")

4、查询变量顺序混乱:"http://www.example.com/test.aspx?bar=1&a=test"

5、含临时的状态变量:http://www.example.com/test?back=/prevpage.aspx

设计URL应该遵循的原则

一、简单,好记

简单好记的域名会给人以深刻的印象。

二、URL中的字母全部用小写

全部用小写,用户比较容易输入,不用因为大小写混合而出现错误,这是人们的输入习惯
有些服务器是区分大小写的,例如Lunix服务器,这样在站长做链接或者是用户输入时,会因为大小写的问题而出现404错误,
而且robots也是区分大小写的,如果大小写搞错了,可能会造成不能收录的严重问题。所以建议所有的URL都使用小写

三、连词符的使用

目录或者文件名中如果有两个单词组成时,一般建议中间使用中划线(-)隔开,
切记不要使用下划线或者其他字符,在搜索引擎中,它是把中划线当作一个空格来处理的,而下划线则是被忽略的,
例如seo-caipiao会被读成seo与caipiao。这是比较友好的写法

四、URL中避免太多参数

设计的则是URL中的参数应该尽量减少,不要超过三个,一般的情况下URL中的参数2-3个就可以了。

五、目录层次尽量少

这里所指的目录层次是指物理目录结构,而不是指逻辑结构,我们在进行URL的设计时,
网站的结构要尽量的去减少目录层次,层次不能太深了,一般建议不要超过三层,特别对于一些新站来说,
权重低,搜索引擎蜘蛛爬行得很浅,深一点的页面,蜘蛛都很可能不会去爬行的,所以要尽量的做到使目录层次减少,
URL缩短。根据观察,百度尤其比较喜欢目录层次比较少的页面。

六、文件名及目录名要具描述性

文件名及目录名要具有可描述性,不但让用户一眼就能看出来这个页面是关于什么的,
对用户体验比较友好,而且搜索引擎也比较喜欢这样的URL。
例如一个关于新闻的目录,我们可以把它命名为news,用户看到这个目录名称,大概就知道这个目录是关于什么内容的了。

七、URL应该呈现一个降级的次序

例如:域名/类型/分类/标题
例如:域名/年/月/日
http://domain.com/news/tech/2007/11/05/google-announces-android

其他

1.URL能反应站点的结构
2.URL是可以被用户猜测和hack的(也鼓励用户如此)
3.永久链接,Cool URLdon't change
4.动态的也要做成伪静态

url规范诞生

一、基本规范

1、不能使用中文单词,最好使用有意义的英文单词,少用拼音。

2、层级不能超过三级。
例如:http://domain.com/xx/xx/xx/xx.html不被允许。

3、URL的参数不允许超过3个

4、URL全部小写

5、网站内部在链接到其他网页,尤其是主页时,只使用一种URL,即不允许同一个资源有多个URL。

6、不允许出现没有意义的下URL
例如:http://www.uxuexi.cn/123.html。谁也看不明白是什么意思。

7、如果是内容资源URL,不允许以参数的方法显示
例如:http://www.uxuexi.cn/user.html?userId=123 需要改成http://www.uxuexi.cn/user/123.html

二、URL类型设置

1、目录
一般用在频道页或是文章栏目(这种方式能获得更多的权重),最后面必须加上“/”
例如:http://www.uxuexi.cn/search需要改成http://www.uxuexi.cn/search/

2、网页
一般用来表现网页内容,需要直接显示在页面的必须以.html结尾
例如:http://www.uxuexi.cn/123 需要改成http://www.uxuexi.cn/user/123.html

3.特定功能或交互式
统一以.json 或者.html结尾
例如:
添加评论 http://www.uxuexi.cn/addcomment.json

三、静态化

1、不经常更新的内容采用静态化。例如:http://course.uxuexi.cn/detail/111.html。URL中不允许使用?带参数。
2、实时更新的内容采用伪静态。例如:http://www.uxuexi.cn/user/111.html。URL中不允许使用?带参数。
特定功能或交互式用动态URL。

约定

所有需要跳转页面的url必须进行统一的管理,统一使用cms:url自定义标签来实现,方便维护和优化。
例如
每次添加url,必须写上注释。
注释url功能,注释每一个参数是什么意思

 

URL命名规则

1、URL中字母全部小写
2、如果有单词拼接,使用中划线‘-’,不使用下划线‘_’

  • 在搜索引擎中,把中划线当做空格处理,而下划线是被忽略的。使用中划线是对搜索引擎友好的写法

3、资源必须采用资源名词的复数形式
4、层级不能超过三层
5、参数不允许超过3个
6、 如果是内容资源的URL,不允许以参数方式显示

  • 例如: http://www.domian/com/users.html?id=1需改成http://www.domian/com/users/1
  • GitHub API规范参考: https://api.github.com/
{
  "current_user_url": "https://api.github.com/user",
  "current_user_authorizations_html_url": "https://github.com/settings/connections/applications{/client_id}",
  "authorizations_url": "https://api.github.com/authorizations", "code_search_url": "https://api.github.com/search/code?q={query}{&page,per_page,sort,order}", "commit_search_url": "https://api.github.com/search/commits?q={query}{&page,per_page,sort,order}", "emails_url": "https://api.github.com/user/emails", "emojis_url": "https://api.github.com/emojis", "events_url": "https://api.github.com/events", "feeds_url": "https://api.github.com/feeds", "followers_url": "https://api.github.com/user/followers", "following_url": "https://api.github.com/user/following{/target}", "gists_url": "https://api.github.com/gists{/gist_id}", "hub_url": "https://api.github.com/hub", "issue_search_url": "https://api.github.com/search/issues?q={query}{&page,per_page,sort,order}", "issues_url": "https://api.github.com/issues", "keys_url": "https://api.github.com/user/keys", "notifications_url": "https://api.github.com/notifications", "organization_repositories_url": "https://api.github.com/orgs/{org}/repos{?type,page,per_page,sort}", "organization_url": "https://api.github.com/orgs/{org}", "public_gists_url": "https://api.github.com/gists/public", "rate_limit_url": "https://api.github.com/rate_limit", "repository_url": "https://api.github.com/repos/{owner}/{repo}", "repository_search_url": "https://api.github.com/search/repositories?q={query}{&page,per_page,sort,order}", "current_user_repositories_url": "https://api.github.com/user/repos{?type,page,per_page,sort}", "starred_url": "https://api.github.com/user/starred{/owner}{/repo}", "starred_gists_url": "https://api.github.com/gists/starred", "team_url": "https://api.github.com/teams", "user_url": "https://api.github.com/users/{user}", "user_organizations_url": "https://api.github.com/user/orgs", "user_repositories_url": "https://api.github.com/users/{user}/repos{?type,page,per_page,sort}", "user_search_url": "https://api.github.com/search/users?q={query}{&page,per_page,sort,order}" }


作者:钱英俊真英俊
链接:https://www.jianshu.com/p/876d4cbd84f9
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

你可能感兴趣的:(如何定义好一个符合规范的url)