Unity now supports .NET 4.5 and I'm able to use the HttpClient class from the System.Net.Http namespace. That is great since I have existing client libraries which are therefore easy to reuse.
Does anyone know the internal difference between using the mono HttpClient and Unity's own networking classes?
I'm afraid that the HttpClient is not as optimized for the different platforms and might therefore cause trouble or be slower.
There are many differences between the two.
UnityWebRequestwon't allow you to use change some headers. WithHttpClient, you can change almost any header.UnityWebRequestis made to be used without worrying about threads or async stuff. All you do is use coroutine to wait for the request. The whole thread stuff is already done for you on the native side.Some platforms don't support anything from the
System.Netnamespace. One of this isWebGL. This means thatHttpClientwill not even compile when you switch your platform to WebGL.UnityWebRequestworks fine with WebGL.UnityWebRequestis made to make it easier to download data in memory and convert the data into Unity resources such asAudioClip,VideoClip,AssetBundle,Texture2Dand more. WithHttpClient, you will have to write lots of codes just retrieve such data or probably have to save the data on the disc after receiving them just to be able to convert them into Unity resources form.Want to use SSL with
UnityWebRequest? Good luck with that! You will only end up with the ambiguous "unknown error" error. When SSL is involved in yourHttpClientis the option.
With everything I just mentioned, you should port your code to use UnityWebRequest unless you are doing something that's not supported with UnityWebRequest.
来源:https://stackoverflow.com/questions/50160380/difference-between-httpclient-and-unitys-unitywebrequest-www-api