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, , byts.Length);
string pa = Encoding.Default.GetString(byts);

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

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

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

05-08 08:42