目录

Lucene.net站内搜索—1、SEO优化
Lucene.net站内搜索—2、Lucene.Net简介和分词
Lucene.net站内搜索—3、最简单搜索引擎代码
Lucene.net站内搜索—4、搜索引擎第一版技术储备(简单介绍Log4Net、生产者消费者模式)
Lucene.net站内搜索—5、搜索引擎第一版实现
Lucene.net站内搜索—6、站内搜索第二版

声明:在这里,所谈的一切关于SEO的技术主要针对于我们开发人员。

SEO (搜索引擎优化)

SEO(搜索引擎优化)的目的(很多人都是通过搜索引擎找到我们的网站)是让搜索引擎更多的收录网站的页面,让被收录页面的权重更靠前,让更多的人能够通过搜索引擎进入这个网站

原理:蜘蛛会定时抓取网站的内容,发现网站内容变化、发现新增内容就反映到搜索引擎中

蜘蛛(spider) 爬网站:就是向网站发http get请求的客户端。

SEO(搜索引擎优化*):让网站排名靠前,让网站更多的页面被搜索引擎收录。链接(外链、内链)、原创、关键词的数量、权重,小偷网站(站群),降权(PR PageRank),K站(Kill站,作弊)、伪原创:

爬网站的过程:发现网站。百度把csdn当成关键网站,顺着已知的网站链接找到新的网站或者新的页面。

SEO的第一个手段:建外链(外部链接)。新网站吸引蜘蛛。对于非新网站,搜索引擎考虑一个“权重”,重点考察
外链数量。权重越高搜索结果越靠前,“权重”的一个重要因素就是“外链”数量,外链质量(外链网站的PR值,PageRank,决定一个网站的质量的
值,PR值越高网站越重要,原创、创建时间等等),Alexa 排名(全球网站排名)

(*)robots.txt是公约,搜索引擎都建议遵守,相当于一个指路牌:想让那些搜索引擎搜索,想让那些页面搜索  Search engine optimization

开发时要考虑SEO

搜索引擎蜘蛛(Spider):向网站发出Get请求,获得页面内容,分析页面中的超链接,进一步的向页面中的超链接发Get请求,获得链接的页面内容。搜索引擎只认识<ahref=“”>,并且不能是JavaScript、超链接不能是js动态生成的

网站的SEO基本原则:所有希望搜索引擎抓取的内容都应该是通过超链接(Get请求)获得的,Post获得的内容、js脚本打开的页面是无法被搜索引擎抓取的,所以尽量不要JS、Post来进行页面导航、内容的生成。搜索引擎一般不会执行JS、不会发Post请求、不会提交表单。

动态菜单应该是把菜单内容静态的写到html中,然后通过隐藏、显示来切换,而不是动态绘制菜单内容。车品汇的案例:在保证动态效果的前提下,考虑SEO。反例:某些校园网站

因为LinkButton是执行JavaScript向服务器发请求来进行Redirect,而蜘蛛不会执行JS,所以尽量不要用LinkButton。

内嵌js生成的超链接是搜索引擎看不到的。服务器端动态生成的内容是可以被蜘蛛看到的,客户端浏览器(蜘蛛)不知道服务器是动态生成的还是静态文
件,只有Response。蜘蛛只分析静态的HTML内容,不会去执行JS。蜘蛛就是相当于发出Get请求的WebClient。禁用JS以后获得的东西
就是蜘蛛能看到的东西。

SEO友好的AJAX:做一个简单的根据参数来获得1、2、3三个文章的AJAX效果,如下示例:

html代码:

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml">
  3. <head>
  4. <title></title>
  5. <script src="jquery-1.4.1.js" type="text/javascript"></script>
  6. <script type="text/javascript">
  7. function getart(id) {
  8. $.post("GetMsg.ashx", { "id": id }, function (data) {
  9. $("#div1").html(data);
  10. });
  11. }
  12. </script>
  13. </head>
  14. <body>
  15. <ul>
  16. <li><a href="GetMsg.ashx?id=1" onclick="getart(1);return false;">1</a></li>
  17. <li><a href="GetMsg.ashx?id=2" onclick="getart(2);return false;">2</a></li>
  18. <li><a href="GetMsg.ashx?id=3" onclick="getart(3);return false;">3</a></li>
  19. </ul>
  20. <div id="div1">
  21. </div>
  22. </body>
  23. </html>

一般处理程序代码:

  1. /// <summary>
  2. /// GetMsg 的摘要说明
  3. /// </summary>
  4. public class GetMsg : IHttpHandler
  5. {
  6. public void ProcessRequest(HttpContext context)
  7. {
  8. context.Response.ContentType = "text/plain";
  9. int id = Convert.ToInt32(context.Request["id"]);
  10. if (id == 1)
  11. {
  12. context.Response.Write(@"搜索引擎蜘蛛(Spider):向网站发出Get请求,获得页面内容,分析页面中的超链接,
  13. 进一步的向页面中的超链接发Get请求,获得链接的页面内容。");
  14. }
  15. else if(id==2)
  16. {
  17. context.Response.Write(@"因为LinkButton是执行JavaScript向服务器发请求来进行Redirect,而蜘蛛不会执行JS,所以尽量不要用LinkButton。");
  18. }
  19. else if (id == 3)
  20. {
  21. context.Response.Write(@"SEO友好的AJAX:做一个简单的根据参数来获得1、2、3三个文章的AJAX效果");
  22. }
  23. }
  24. public bool IsReusable
  25. {
  26. get
  27. {
  28. return false;
  29. }
  30. }
  31. }

效果:

这样就可以既实现ajax效果,又利于SEO优化了。

WebClient是下载Get请求的结果,而不是下载aspx源码。

聊SEO的时候说的一个很牛的技巧:<a href=“GetArticle.ashx?Id=1”
onclick=“ShowArticle(1);return
false;”>文章1</a>,也对不支持JavaScript的浏览器提供友好的使用。

糗事百科的“评论”也是同时考虑AJAX和SEO的例子。

蜘蛛爬网原理代码:

  1. WebClient wc = new WebClient();
  2. string html = wc.DownloadString("http://www.baidu.com");
  3. //把html放入“数据库”
  4. //分析html中的超链接 links
  5. //foreach(string link in links)
  6. //string html2 = wc.DownloadString(link);

聊到SEO的话!!!

对于开发人员来讲:搜索引擎只认get请求获得的原始源代码;只认页面中的a标签,并且不能是href=“javascript:”;

案例:不要是<ahref="javascript:document.location='http://www.baidu.com'" >百度</a>

不要用LinkButton的Onclick中来做Response.Redirect,因为生成的是js,请看如下代码:

  1. <asp:LinkButton ID="LinkButton1" runat="server" onclick="LinkButton1_Click">LinkButton</asp:LinkButton>

生成的html源码如下:

  1. <a id="LinkButton1" href="javascript:__doPostBack('LinkButton1','')">LinkButton</a>

不要在页面中动态通过js生成超链接菜单,而应该像“车品汇”一样先把链接都生成到页面中,只是隐藏,然后通过js来控制不同层的显示

实现AJAX,同时制定onclick和href,让普通用户走onclick的ajax效果,搜索引擎蜘蛛走href

关于搜索

开发百度用的是通用搜索,咱们主要做站内搜索。

有一定访问量的互联网站都有站内搜索功能,比如verycd、优酷、豆瓣、cnblogs、mop、淘宝、大众点评网等。

msg like '%.net视频教程%':模糊程度太低,无法匹配几个关键词不挨着的;造成全表扫描,效率低。

为什么不用数据库全文检索?数据库全文检索很傻瓜化,和普通SQL一样。数据全文检索灵活性不强。注意:要sqlserver的专业版才支持全文检索功能。

使用sqlserver全文检索步骤:

1、设置需要检索的列属性

2、全文检索的查询语法:select * from T where contains(msg,’你好’)

为什么不用百度、google的站内搜索(site:cnblogs.com):受制于人,会被K;索引不及时、不全面、不精准;用户体验感差

这里主要讲解最有广泛应用价值的站内搜索技术,像开发百度、google那种站外搜索相关的技术不讲。

a、  搜索引擎 site:www.cnblogs.com 站内搜索

b、  查看网站收录。site:www.verycd.com

当我们新建一个网站后,要想让搜索引擎能够收录,我们要先将我们网址提交到各搜索引擎入口,一般提交2~3天后,你就可以在各搜索引擎中输入关键字进行搜索了。

Lucene.net站内搜索—1、SEO优化的更多相关文章

  1. Lucene.net站内搜索—6、站内搜索第二版

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  2. Lucene.net站内搜索—5、搜索引擎第一版实现

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  3. Lucene.net站内搜索—4、搜索引擎第一版技术储备(简单介绍Log4Net、生产者消费者模式)

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  4. Lucene.net站内搜索—3、最简单搜索引擎代码

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  5. Lucene.net站内搜索—2、Lucene.Net简介和分词

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  6. Lucene.Net 站内搜索

    Lucene.Net 站内搜索 一  全文检索: like查询是全表扫描(为性能杀手)Lucene.Net搜索引擎,开源,而sql搜索引擎是收费的Lucene.Net只是一个全文检索开发包(只是帮我们 ...

  7. Lucene.net站内搜索-最简单搜索引擎代码

    Lucene.Net核心类简介 先运行写好的索引的代码,再向下讲解各个类的作用,不用背代码. (*)Directory表示索引文件(Lucene.net用来保存用户扔过来的数据的地方)保存的地方,是抽 ...

  8. 站内搜索——Lucene +盘古分词

    为了方便的学习站内搜索,下面我来演示一个MVC项目. 1.首先在项目中[添加引入]三个程序集和[Dict]文件夹,并新建一个[分词内容存放目录] Lucene.Net.dll.PanGu.dll.Pa ...

  9. 使用Lucene.NET实现简单的站内搜索

    使用Lucene.NET实现简单的站内搜索 导入Lucene.NET 开发包 Lucene 是apache软件基金会一个开放源代码的全文检索引擎工具包,是一个全文检索引擎的架构,提供了完整的查询引擎和 ...

随机推荐

  1. JS 内置对象

    内置对象的定义:有ECMAScript实现提供的.不依赖与宿主环境的对象,在ECMAScript运行之前就已经创建好的对象就叫做内置对象. 就是说,是不需要我们开发人员先是的实例化对象就能够调用和运行 ...

  2. Yii2框架RESTful API教程(二) - 格式化响应,授权认证和速率限制

    之前写过一篇Yii2框架RESTful API教程(一) - 快速入门,今天接着来探究一下Yii2 RESTful的格式化响应,授权认证和速率限制三个部分 一.目录结构 先列出需要改动的文件.目录如下 ...

  3. vm中centos7配置静态ip访问外网

    我使用的是桥接方式,具体步骤如下   1.设置虚拟机网络: 编辑>虚拟网络编辑器   2.设置vm中操作系统的网络设置   3.进入centos7中后修改网络配置:     另附我的宿主机网络配 ...

  4. MVVM模式下,ViewModel和View,Model有什么区别

    摘自正美的5群 Model:很简单,就是业务逻辑相关的数据对象,通常从数据库映射而来,我们可以说是与数据库对应的model. View:也很简单,就是展现出来的用户界面. 基本上,绝大多数软件所做的工 ...

  5. fabric upgrade from old crashlystic stuck in build

    提示build,一直没有反应. 问题:工程中原有的shell命令屏蔽掉了

  6. Android属性动画之第一重修炼总结

    经过这两天对ObjectAnimator属性动画的学习,基本对Android提供的属性动画有了一定的认识,现在就为大家以一个类似扇形打开的效果做总结. 效果图: 下面就让我们用刚刚学到的属性动画效果, ...

  7. [java] 汇率换算器实现(2)

    [java] 汇率换算器实现(2) // */ // ]]> // */ // ]]>   [java] 汇率换算器实现(2) Table of Contents 1 系列文章地址 2 前 ...

  8. [New Portal]Windows Azure Cloud Service (34) TechEd 2013 North America关于Azure的最新消息

    <Windows Azure Platform 系列文章目录> 话说TechEd 2013 US上个月3-6日在美国举办了,笔者的文章又有点姗姗来迟了. 需要了解相关视频的网友,请浏览ht ...

  9. SwiftLint——Swift代码检查及自动格式化工具

    某软不给力,正在做的UWP项目停工了.官方说法是要等到RS2发布新的VOIP架构,再看看是不是给某软面子.虽然Beta用户中发出了几点愤怒的声音,但是木有用.有用的只能是某软的Skype for bu ...

  10. 爬虫--Scrapy

    Scrapy Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 其可以应用在数据挖掘,信息处理或存储历史数据等一系列的程序中.其最初是为了页面抓取 (更确切来说, 网络抓取 )所设 ...