array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(3) "428" ["text"]=> string(77) "Visual Studio 2017 单独启动MSDN帮助(Microsoft Help Viewer)的方法" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(8) "DonetRen" ["tagsname"]=> string(55) "Visual Studio 2017|MSDN帮助|C#程序|.NET|Help Viewer" ["tagsid"]=> string(23) "[401,402,403,"300",404]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400964" ["_id"]=> string(3) "428" } [1]=> array(10) { ["id"]=> string(3) "427" ["text"]=> string(42) "npm -v;报错 cannot find module "wrapp"" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "zzty" ["tagsname"]=> string(50) "node.js|npm|cannot find module "wrapp“|node" ["tagsid"]=> string(19) "[398,"239",399,400]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400760" ["_id"]=> string(3) "427" } [2]=> array(10) { ["id"]=> string(3) "426" ["text"]=> string(54) "说说css中pt、px、em、rem都扮演了什么角色" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(12) "zhengqiaoyin" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511400640" ["_id"]=> string(3) "426" } [3]=> array(10) { ["id"]=> string(3) "425" ["text"]=> string(83) "深入学习JS执行--创建执行上下文(变量对象,作用域链,this)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "Ry-yuan" ["tagsname"]=> string(33) "Javascript|Javascript执行过程" ["tagsid"]=> string(13) "["169","191"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511399901" ["_id"]=> string(3) "425" } [4]=> array(10) { ["id"]=> string(3) "424" ["text"]=> string(30) "C# 排序技术研究与对比" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "vveiliang" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(8) ".Net Dev" ["catesid"]=> string(5) "[199]" ["createtime"]=> string(10) "1511399150" ["_id"]=> string(3) "424" } [5]=> array(10) { ["id"]=> string(3) "423" ["text"]=> string(72) "【算法】小白的算法笔记:快速排序算法的编码和优化" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(9) "penghuwan" ["tagsname"]=> string(6) "算法" ["tagsid"]=> string(7) "["344"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511398109" ["_id"]=> string(3) "423" } [6]=> array(10) { ["id"]=> string(3) "422" ["text"]=> string(64) "JavaScript数据可视化编程学习(二)Flotr2,雷达图" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "chengxs" ["tagsname"]=> string(28) "数据可视化|前端学习" ["tagsid"]=> string(9) "[396,397]" ["catesname"]=> string(18) "前端基本知识" ["catesid"]=> string(5) "[198]" ["createtime"]=> string(10) "1511397800" ["_id"]=> string(3) "422" } [7]=> array(10) { ["id"]=> string(3) "421" ["text"]=> string(36) "C#表达式目录树(Expression)" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(4) "wwym" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1511397474" ["_id"]=> string(3) "421" } [8]=> array(10) { ["id"]=> string(3) "420" ["text"]=> string(47) "数据结构 队列_队列实例:事件处理" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(7) "idreamo" ["tagsname"]=> string(40) "C语言|数据结构|队列|事件处理" ["tagsid"]=> string(23) "["246","247","248",395]" ["catesname"]=> string(12) "数据结构" ["catesid"]=> string(7) "["133"]" ["createtime"]=> string(10) "1511397279" ["_id"]=> string(3) "420" } [9]=> array(10) { ["id"]=> string(3) "419" ["text"]=> string(47) "久等了,博客园官方Android客户端发布" ["intro"]=> string(288) "目录 ECharts 异步加载 ECharts 数据可视化在过去几年中取得了巨大进展。开发人员对可视化产品的期望不再是简单的图表创建工具,而是在交互、性能、数据处理等方面有更高的要求。 chart.setOption({ color: [ " ["username"]=> string(3) "cmt" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1511396549" ["_id"]=> string(3) "419" } } ["count"]=> int(200) } 222 MVC自定义错误页404静态页 - 爱码网

昨天公司要求给所有项目添加自定义404错误页,具体的要求实现的有以下几点:

1.实现自定义错误(如各种error,404等)跳转到指定的页面

2.所指定的页面输出的http状态值必须是404或其他指定的statecode

3.跳转到的自定义错误页面必须是.html后缀结尾

关于第一点,这个很简单,大家都知道,只需要在webconfig里面对customErrors节点作相应设置,如下

<customErrors mode="On" defaultRedirect="Error.html">
            <error statusCode="404" redirect="404NotFond.html"></error>
        </customErrors>

 由于真正的html静态页输出的http状态值只能是200(ok),所以,为了使输出的statuscode为404或其他值,必须将它伪静态化,在MVC里,将一个html页实现伪静态的效果也很简单,只需要对路由做些配置,在Global.aspx.cs文件里

        /// <summary>
        /// 路由控制
        /// </summary>
        /// <param name="routes"></param>
        public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
            //routes.IgnoreRoute("{resource}.jpg");

            #region 错误页路由
            routes.MapRoute(
                "404NotFund",// Route name
                "404NotFond.html",// URL with parameters
                new
                {
                    controller = "Error",
                    action = "error"
                }  // Parameter defaults
            );
            routes.MapRoute(
                "Error",// Route name
                "Error.html",// URL with parameters
                new
                {
                    controller = "Error",
                    action = "error"
                }  // Parameter defaults
            );
            #endregion
        }    

 在这里,我们将两个自定义错误页的路由都指向了ErrorController下的名为error的Action,接下来,就需要告诉这个Action对外输出的statuscode

public class ErrorController : Controller {
        /// <summary>
        /// 页面错误
        /// </summary>
        /// <returns></returns>
        public ActionResult error() {
            Response.Status = "404 Not Found";
            Response.StatusCode = 404;
            return View();
        }
}

 这里,我们指定它输出的StatusCode为404,接下来,你就可以去粉饰你真正的404自定义错误页,也就是这个Action输出的页面Views/Error/error.aspx

这些都做完之后,你就可以在本地开始调试看看效果了,不过在调试之前,一定要将项目里error.html和404NotFond.html页面删掉,因为,在MVC默认设置中,如果访问路径URL中的静态文件在项目中存在,它会优先取静态文件,从而绕过了路由,那么此时你的global里对这些静态文件路由的设置将毫无用处

确保你的项目里不存在相同路径下同名的静态文件后,在本地调试,应该可以就达到预期效果了

不过,当我把项目部署到服务器的IIS7上的的时候,发现在本地访问服务器上的,始终出来的都是

MVC自定义错误页404静态页
并不是我指定的自定义错误页,但是在本地调试程序,以及用服务器上的浏览器打开看却又是正常的,所以,我怀疑是IIS在搞鬼
经过大半个下午的挣扎思索,最终让我找到了一个关键点,在IIS的站点设置里
MVC自定义错误页404静态页
有一项关于“错误页”的设置
MVC自定义错误页404静态页
 

右键404——》编辑功能设置

MVC自定义错误页404静态页

点击打开

MVC自定义错误页404静态页

默认设置的是“本地请求的详细错误和远程请求的自定义错误”,这个意思是,如果本地打开(在服务器用浏览器打开)它展示的是详细错误,如果是远程请求(外网访问服务器)它展示的是自定义错误页,而它(IIS)理解的自定义错误页是

MVC自定义错误页404静态页

这样一来,就好理解了,知道该怎么办了

办法有三个,一是“编辑错误页设置”面板里设为始终展示“详细信息”,二是“编辑自定义错误页”面板里修改文件路径到你自定义的html错误页

三是在webconfig的<system.webServer>节点里添加

<httpErrors>
            <remove statusCode="404" subStatusCode="-1" />
            <error statusCode="404" prefixLanguageFilePath="" path="http://www.uzai.com/404NotFond.html" responseMode="Redirect" />
        </httpErrors>

 有的时候,由于服务器IIS给的权限不够大,还不足以修改httperrors里的配置,这个时候需要在服务器上以管理员的身份运行一下命令来解禁:

%windir%\system32\inetsrv\appcmd unlock config -section:system.webServer/httpErrors

 三个方法任选其一,有时也可能需要混合使用,具体是情况而定

此博文为本人原创,若要转载,请标明出处~

相关文章: