.NET URL 301转向方法的实现

 说说为什么会用到URL301转向的原因。最近项目开发中遇到需要将原有功能页面改变为新功能的页面的需要,但SEO方面需要考虑对搜索引擎的友好。举个简单的例子,原页面A(显示用户的收藏),产品部最近有新的需求,显示用户的收藏,但显示的样式和UI的操作方式上有改变,这样我们就需要新的页面B。A页面在正式上线后是可以废弃的,但这里存在一个问题就是一但废弃了A页面,原来搜索引擎收录的A页面会报错。如果保留A页面,长时间下去,整个Web系统就变的臃肿(这次改版比较大,类似A这样的页面比较多)。那么如何告诉搜索引擎,我这个页面是废弃的页面,请将这个页面地址更新到新的页面呢。要完成这个功能还得先提到Http协议中3XX的一些简介:

301:重定向,表示本网页永久性转移到另一个地址。

302:暂时转向,表示本网页暂时性的转移到另一个地址。

      从上面的介绍中我们就可以看到要完成上面的需求,只要使用301这个状态就可以了。那么我们平时使用的Response.Redirect是什么转向呢?它完成的其实是302转向的功能。这是通过HttpWatch看到的结果:

1 

       Rsponse.Redirect不能使用,那么只能通过修改Http头的Status来实现了,C#中 通过设置 Response.Status 来完成这个工作,下面的代码是参考网上的做法实现的。我们这里需要在A页面实现通知搜索引擎实现301转向(转向页面是B.aspx),那么在A页面的OnLoad实现如下代码:

HttpContext context = HttpContext.Current;
context.Response.Status = "301 Moved Permanently";
context.Response.AddHeader("Location", ResolveUrl("b.aspx"));
context.Response.End();

HttpWatch中看到的结果:

2 

从图中可以看到,已经实现301转向了。对于程序本身来说使用301或302转向没什么区别,反而302使用方便。但从SEO方面考虑,采用301转向就有重要意义了。

  1. 网址规范,将多个域名统一到主域名下,301转向可以避免搜索引擎作弊嫌疑。
  2. 网页PR值统一到一个页面。A通过301转向到B页面,那么A页面的PR值也会转移到B页面。

具体可以参考:301转向的方法和网址规范化 中的说明。

从301转向上,我们还可看到关于404,500的处理情况,它的实现比较类同:

Response.Status="404 Not Found"

Response.Status="500 Internal Server Error"

 

 

用Javascript将图片等比例缩放

并非原创,主要是产品部的需求。对网站商户图片进行等比例缩放。

script:
function resizeimg(ImgD,iwidth,iheight) {
     var image=new Image();
     image.src=ImgD.src;
     if(image.width>0 && image.height>0){
        if(image.width/image.height>= iwidth/iheight){
           if(image.width>iwidth){
               ImgD.width=iwidth;
               ImgD.height=(image.height*iwidth)/image.width;
           }else{
                  ImgD.width=image.width;
                  ImgD.height=image.height;
                }
               ImgD.alt=image.width+"×"+image.height;
        }
        else{
                if(image.height>iheight){
                       ImgD.height=iheight;
                       ImgD.width=(image.width*iheight)/image.height;
                }else{
                        ImgD.width=image.width;
                        ImgD.height=image.height;
                     }
                ImgD.alt=image.width+"×"+image.height;
            }
ImgD.style.cursor= "pointer"; //改变鼠标指针
ImgD.onclick = function() { window.open(this.src);} //点击打开大图片
if (navigator.userAgent.toLowerCase().indexOf("ie") > -1) { //判断浏览器,如果是IE
ImgD.title = "请使用鼠标滚轮缩放图片,点击图片可在新窗口打开";
ImgD.onmousewheel = function img_zoom() //滚轮缩放
 {
var zoom = parseInt(this.style.zoom, 10) || 100;
zoom += event.wheelDelta / 12;
if (zoom> 0) this.style.zoom = zoom + "%";
return false;
 }
  } else { //如果不是IE
     ImgD.title = "点击图片可在新窗口打开";
   }
    }
}
HTML:
<img id="imgDoc" border="0" src="test.jpg" onload="javascript:resizeimg(this,400,300);" >

 

posted @ 2009-12-07 09:33  leeolevis  阅读(310)  评论(0编辑  收藏  举报