zoukankan      html  css  js  c++  java
  • WebAPI获取客户端请求数据

    1.什么是WebAPI,详见:http://www.cxyclub.cn/n/25123/
    2.一般情况下我们不需要去关心客户端的请求数据,WebAPI会通过自己的方式去将客户端请求的数据转换为实体对象,我们在接口里面定义实体就可以接收数据,但是公司要求必须要记录客户端的请求数据到日志中,于是我们就创建了一个拦截器来处理。
    拦截器需要继承ActionFilterAttribute并重写方法OnActionExecuting(HttpActionContext actionContext),然后在方法里面通过如下代码记录客户端数据:

    var request = HttpContext.Current.Request;
    byte[] byts = new byte[request.InputStream.Length];
    request.InputStream.Read(byts, 0, byts.Length);
    string pa = Encoding.Default.GetString(byts);

    奇迹出现了,你会发现你永远都无法获得数据,pa的值永远为空,怎么办呢?查看多方面资料后发现,C#中的流数据读取一次之后下标就到了最后,我们再次读取时必须要将位置设置为0,代码如下:

    var request = HttpContext.Current.Request;
    request.InputStream.Position = 0;//核心代码
    byte[] byts = new byte[request.InputStream.Length];
    request.InputStream.Read(byts, 0, byts.Length);
    string pa = Encoding.Default.GetString(byts);

    记录一下,以后遇到也好解决。

  • 相关阅读:
    持续集成之Jenkins+sonar自动化部署04
    自动化部署03
    自动化部署02
    自动化部署01
    持续集成之代码质量管理-Sonar
    gitlab-ce安装01
    在Centos7.3安装Zabbix3.4.4服务端
    自动化运维之日志系统上线规范(十)
    自动化运维之日志系统Logstash实践(九)
    自动化运维之日志系统Logstash解耦实践(八)
  • 原文地址:https://www.cnblogs.com/duanjt/p/6734372.html
Copyright © 2011-2022 走看看