admin管理员组文章数量:1612097
<>
安全地使用HttpContext.Current
有时我们会写些通用类库给ASP.NET或者WindowsService程序来使用,例如异常记录的工具方法。 对于ASP.NET程序来说,我们肯定希望在异常发生时,能记录URL,表单值,Cookie等等数据,便于事后分析。 然而对于WindowsService这类程序来说,您肯定没想过要记录Cookie吧? 那么如何实现一个通用的功能呢?
方法其实也简单,就是要判断HttpContext.Current是否返回null,例如下面的示例代码:
public static void LogException(Exception ex) { StringBuilder sb = new StringBuilder(); sb.Append("异常发生时间:").AppendLine(DateTime.Now.ToString()); sb.AppendLine(ex.ToString()); // 如果是ASP.NET程序,还需要记录URL,FORM, COOKIE之类的数据 HttpContext context = HttpContext.Current; if( context != null ) { // 能运行到这里,就肯定是在处理ASP.NET请求,我们可以放心地访问Request的所有数据 sb.AppendLine("Url:" + context.Request.RawUrl); // 还有记录什么数据,您自己来实现吧。 } System.IO.File.AppendAllText("日志文件路径", sb.ToString()); }
就是一个判断,解决了所有问题,所以请忘记下面这类不安全的写法吧:
HttpContext.Current.Request.RawUrl; HttpContext.Current.Server.MapPath("xxxxxx");
下面的方法才是安全的:
HttpContext context = HttpContext.Current; if( context != null ) { // 在这里访问与请求有关的东西。 }
本文标签: HttpContextCurrent
版权声明:本文标题:安全地使用HttpContext.Current 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://www.elefans.com/dianzi/1728630261a1167004.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论