大家好,今天小编来为大家解答asp网站源码分享怎么安装这个问题,asp源码怎么运行很多人还不知道,现在让我们一起来看看吧!
首先给出正确和错误做法,然后对比这两种做法。
1正确的做法
publicclassAvaterController:BaseApiController\n{\n\t[HttpPost]\npublicasyncTask<IHttpActionResult>UploadAvater(intuserId)\n{\nAvatarBLLpictureBLL=newAvatarBLL(this.Request);\nawaitpictureBLL.UploadAvatar(userId);\nreturnOk();\n\t}\n\t\n\t//其他Action\n}\n\npublicclassAvatarBLL\n{\n\tprivateHttpRequestMessageHttpRequestMessage;\n\tpublicAvatarBLL(HttpRequestMessagehttpRequestMessage)\n\t{\n\tthis.HttpRequestMessage=httpRequestMessage;\n\t}\n\tpublicasyncTaskUploadAvatar(intuserId)\n{\nif(!HttpRequestMessage.Content.IsMimeMultipartContent(“form-data”))\n{\n//抛异常\n}\n\t//获得客户端传递到服务器的数据\nList<byte>list=newList<byte>();\nawaitHttpRequestMessage.Content.ReadAsMultipartAsync().ContinueWith(multipartContent=>\n{\nif(multipartContent.IsFaulted||multipartContent.IsCanceled)\n{\n//抛异常\n}\n\nforeach(varcontentinmultipartContent.Result.Contents)\n{\nvarb=content.ReadAsByteArrayAsync().Result;\nlist.AddRange(b);\n}\n\t});\n\t\n\t//其他部分(将数据存入Mongodb以及其他的业务逻辑)\n\t}\n}\n
2错误的做法
publicclassAvaterController:BaseApiController\n{\n\t[HttpPost]\npublicIHttpActionResultUploadAvater(intuserId)\n{\nAvatarBLLpictureBLL=newAvatarBLL(this.Request);\npictureBLL.UploadAvatar(userId);\nreturnOk();\n\t}\n\t\n\t//其他Action\n}\npublicclassAvatarBLL\n{\n\tprivateHttpRequestMessageHttpRequestMessage;\n\tpublicAvatarBLL(HttpRequestMessagehttpRequestMessage)\n\t{\n\tthis.HttpRequestMessage=httpRequestMessage;\n\t}\n\tpublicvoidUploadAvatar(intuserId)\n{\nif(!HttpRequestMessage.Content.IsMimeMultipartContent(“form-data”))\n{\n//抛异常\n}\n\t//获得客户端传递到服务器的数据\nList<byte>list=newList<byte>();\nMemoryStreamms=newMemoryStream();\ntry\n{\nMultipartMemoryStreamProvidermmsp=newMultipartMemoryStreamProvider();\nvartask=\t\t\t\t\t\tHttpRequestMessage.Content.ReadAsMultipartAsync<MultipartMemoryStreamProvider>(mmsp,100000);\ntask.Wait();\nvarcontents=task.Result.Contents;\n\nforeach(varcincontents)\n{\nvarb=c.ReadAsByteArrayAsync();\nb.Wait();\nlist.AddRange(b.Result);\n}\n}\ncatch(AggregateExceptionex)\n\t{}\n\n\t//其他部分(将数据存入Mongodb以及其他的业务逻辑)\n\t}\n}\n
3错误现象:
采用第二种方式,如果客户端上传到服务的数据量(调用UploadAvater上传的数据)小于服务端设置的缓冲区的大小,那么可正常上传文件,如果大于服务端设置的缓冲区的大小,则无法正常上传,调试服务端代码,当执行到task.Wait();这行语句时,客户端一直等待,直到客户端调用超时,永远也无法返回调用结果,发生了死锁!!!使用HttpRequestMessage.Content.ReadAsMultipartAsync<MultipartMemoryStreamProvider>(mmsp,1000);设置缓冲区大小为1000bit。这个方法有几个重载的方法,其中一个是不显示设置缓冲区大小,那么缓冲区大小为默认的。
4对第二种方法的错误点分析:
看Webapidll源码中的设置:
可以看出默认的缓冲区区大小为32*1024,即32K,那么上传超过32k而不设置缓冲区大小的情况下,为什么会发生死锁,而将缓冲区设置超过上传文件大小为什么不会发生死锁呢?
不论是否将缓冲区大小设置的足够大,都有发生死锁的可能。
主要的方法见上图,在方法体中有下面这段代码:
这段代码的核心方法:
上面的方法,循环读取请求数据,当设置的缓冲区大小小于客户端发送到服务器的数据量时,要执行多次循环读取数据,每次循环读取数据都是调用两个异步方法:
然而,ReadAsMultipartAsync方法的返回值是Task<T>(T为streamProvider),所以当调用Task.Wait()方法等待的时候,ReadAsMultipartAsync方法内部也在等待异步处理streamProvider返回结果,这样就造成了死锁。
5第一种方法为什么不会出现死锁?
第一种方法使用await,实现同步机制,而没有调用Task.Wait()方法,这样就避免了A、B两块代码块互相等待返回结果而导致死锁的可能。
关于asp网站源码分享怎么安装和asp源码怎么运行的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
