asp.Net   发布时间:2022-04-07  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了asp.net-mvc – 缩小ASP.NET MVC中的Action Filter属性大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个控制器动作,返回大量的动态 JavaScript(一次服务到客户端),我已经启用了GZip压缩.我想做的一件事是阅读执行的结果流并对其应用JS缩小.

是否可以使用动作过滤器属性执行此操作.我想我的问题归结为 – 假设我的minifier需要一串JavaScript,有没有办法将执行结果拉出View(view).ExecuteResult(ControllerContext)?

解决方法

我认为YUI Compressor for .NET将完全满足您的需求.

http://yuicompressor.codeplex.com/

编辑:上面错了,因为我误解了这个问题.下面的代码将安装一个响应过滤器,允许您操作输出,在这种情况下,它只是删除换行符.

希望这可以帮助.

[HandleError]
public class HomeController : Controller
{
    [Minify]
    public ActionResult Index()
    {
        ViewData["message"] = "Welcome to ASP.NET MVC!";

        return View();
    }
}

public class Minify : ActionFilterAttribute
{
    public override void OnActionExecuTing(ActionExecuTingContext filterContext)
    {
        //You can check if the content type is CSS/JS here and prevent the filter running on HTML pages 

        filterContext.httpContext.Response.Filter = new MinifyFilter(filterContext.httpContext.Response.Filter);

        base.onActionExecuTing(filterContext);
    }
}

public class MinifyFilter : MemoryStream
{
    private StringBuilder outputString = new StringBuilder();
    private Stream outputStream = null;

    public MinifyFilter(Stream outputStream)
    {
        this.outputStream = outputStream;
    }

    public override void Write(byte[] buffer,int offset,int count)
    {
        outputString.Append(Encoding.UTF8.GetString(buffer));
    }

    public override void Close()
    {
        //Call the minifier here,your data is in outputString
        String result = outputString.ToString().replace(Environment.NewLine,String.Empty);

        byte[] rawResult = Encoding.UTF8.GetBytes(result);
        outputStream.Write(rawResult,rawResult.Length);

        base.Close();
        outputStream.Close();
    }
}

大佬总结

以上是大佬教程为你收集整理的asp.net-mvc – 缩小ASP.NET MVC中的Action Filter属性全部内容,希望文章能够帮你解决asp.net-mvc – 缩小ASP.NET MVC中的Action Filter属性所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。