Este é o código que tenho até agora:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System;
using System.Net.Http;
using System.Web;
using System.Net;
using System.IO;
namespace ConsoleProgram
{
public class Class1
{
private const string URL = "https://sub.domain.com/objects.json?api_key=123";
private const string DATA = @"{""object"":{""name"":""Name""}}";
static void Main(string[] args)
{
Class1.CreateObject();
}
private static void CreateObject()
{
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(URL);
request.Method = "POST";
request.ContentType = "application/json";
request.ContentLength = DATA.Length;
StreamWriter requestWriter = new StreamWriter(request.GetRequestStream(), System.Text.Encoding.ASCII);
requestWriter.Write(DATA);
requestWriter.Close();
try {
WebResponse webResponse = request.GetResponse();
Stream webStream = webResponse.GetResponseStream();
StreamReader responseReader = new StreamReader(webStream);
string response = responseReader.ReadToEnd();
Console.Out.WriteLine(response);
responseReader.Close();
} catch (Exception e) {
Console.Out.WriteLine("-----------------");
Console.Out.WriteLine(e.Message);
}
}
}
}
O problema é que acho que o bloco de exceção está sendo acionado (porque quando removo a tentativa de captura, recebo uma mensagem de erro do servidor (500). Mas não vejo as linhas Console.Out que coloco no bloco de captura.
Meu console:
The thread 'vshost.NotifyLoad' (0x1a20) has exited with code 0 (0x0).
The thread '<No Name>' (0x1988) has exited with code 0 (0x0).
The thread 'vshost.LoadReference' (0x1710) has exited with code 0 (0x0).
'ConsoleApplication1.vshost.exe' (Managed (v4.0.30319)): Loaded 'c:\users\l. preston sego iii\documents\visual studio 11\Projects\ConsoleApplication1\ConsoleApplication1\bin\Debug\ConsoleApplication1.exe', Symbols loaded.
'ConsoleApplication1.vshost.exe' (Managed (v4.0.30319)): Loaded 'C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System.Configuration\v4.0_4.0.0.0__b03f5f7f11d50a3a\System.Configuration.dll', Skipped loading symbols. Module is optimized and the debugger option 'Just My Code' is enabled.
A first chance exception of type 'System.Net.WebException' occurred in System.dll
The thread 'vshost.RunParkingWindow' (0x184c) has exited with code 0 (0x0).
The thread '<No Name>' (0x1810) has exited with code 0 (0x0).
The program '[2780] ConsoleApplication1.vshost.exe: Program Trace' has exited with code 0 (0x0).
The program '[2780] ConsoleApplication1.vshost.exe: Managed (v4.0.30319)' has exited with code 0 (0x0).
Estou usando o Visual Studio 2011 Beta e o .NET 4.5 Beta.
Respostas:
A API da Web do ASP.Net substituiu a API da Web do WCF mencionada anteriormente.
Eu pensei em postar uma resposta atualizada, já que a maioria dessas respostas é do início de 2012, e esse tópico é um dos principais resultados ao fazer uma pesquisa no Google por "chamar serviço repousante c #".
A orientação atual da Microsoft é usar as Bibliotecas cliente da API da Web do Microsoft ASP.NET para consumir um serviço RESTful. Está disponível como um pacote NuGet, Microsoft.AspNet.WebApi.Client. Você precisará adicionar este pacote NuGet à sua solução.
Veja como o seu exemplo ficaria quando implementado usando a biblioteca cliente da API da Web do ASP.Net:
Se você planeja fazer várias solicitações, reutilize sua instância HttpClient. Consulte esta pergunta e suas respostas para obter mais detalhes sobre por que uma instrução using não foi usada na instância HttpClient neste caso: HttpClient e HttpClientHandler precisam ser descartados?
Para mais detalhes, incluindo outros exemplos, acesse aqui: http://www.asp.net/web-api/overview/web-api-clients/calling-a-web-api-from-a-net-client
Esta publicação no blog também pode ser útil: http://johnnycode.com/2012/02/23/consuming-your-own-asp-net-web-api-rest-service/
fonte
ReadAsAsync()
, adicione uma referência aSystem.Net.Http.Formatting.dll
. (Intuitivo, certo?)Minha sugestão seria usar o RestSharp . Você pode fazer chamadas para os serviços REST e convertê-los em objetos POCO com muito pouco código padrão, para realmente precisar analisar a resposta. Isso não resolverá seu erro específico, mas responde à sua pergunta geral sobre como fazer chamadas para serviços REST. Ter que alterar seu código para usá-lo deve compensar a facilidade de uso e a robustez do futuro. Isso é apenas meus 2 centavos embora
Exemplo:
fonte
Sem relação, tenho certeza, mas envolva seus
IDisposable
objetos emusing
blocos para garantir o descarte adequado:fonte
Aqui estão algumas maneiras diferentes de chamar uma API externa em C # (atualizado em 2019).
Maneiras internas do .NET:
Pacotes NuGet gratuitos e de código aberto , que francamente têm uma experiência de desenvolvedor muito melhor do que os clientes internos do .NET:
Todos os pacotes acima fornecem uma ótima experiência para o desenvolvedor (API concisa e fácil) e são bem mantidos.
(*) em agosto de 2019
Exemplo: Obtendo um item Todo a partir de uma API Fake Rest usando ServiceStack.Text. As outras bibliotecas têm sintaxe muito semelhante.
A execução do exemplo acima em um aplicativo .NET Core Console produz a seguinte saída.
Instale esses pacotes usando o NuGet
fonte
Use o código abaixo para sua solicitação de API REST
fonte
Gostaria de compartilhar minha solução no ASP.NET Core
Para postar use algo como isto:
Exemplo para excluir:
Exemplo para obter a lista:
Exemplo para obter apenas um:
fonte
Atualização para chamar uma API REST ao usar o .NET 4.5 ou .NET Core
Gostaria de sugerir DalSoft.RestClient (ressalva que eu criei). O motivo é que, devido à digitação dinâmica, você pode encerrar tudo em uma chamada fluente, incluindo serialização / desserialização. Abaixo está um exemplo de PUT em funcionamento:
fonte
OBTER:
POSTAR:
Nota: Para serializar e dessirializar o JSON, usei o pacote Newtonsoft.Json NuGet.
fonte
Confira Remontar para fazer chamadas para descansar serviços de .net. Achei muito fácil de usar: https://github.com/paulcbetts/refit
fonte
Este é um código de exemplo que funciona com certeza. Levei um dia para fazer isso para ler um conjunto de objetos do serviço Rest:
RootObject é o tipo de objeto que estou lendo no serviço restante.
fonte
fonte
Eu fiz isso dessa maneira simples, com a web Api 2.0. Você pode remover UseDefaultCredentials.I usado para meus próprios casos de uso.
fonte
Como você está usando o Visual Studio 11 Beta, convém usar o mais recente e o melhor. A nova API da Web contém classes para isso.
Consulte HttpClient: http://wcf.codeplex.com/wikipage?title=WCF%20HTTP
fonte
A resposta marcada aqui sugere usar o HttpClient diretamente e descartá-lo. Isso pode funcionar, mas é muito fácil encontrar problemas com o HttpClient se você não usá-lo corretamente. Se você usar o HttpClient, é melhor entregar a criação / descarte do HttpClients a uma biblioteca de terceiros que usa padrão de fábrica. RestClient.Net é uma dessas bibliotecas.
Ele vem com uma fábrica HttpClient muito básica, para que você não encontre o problema de exaustão do soquete,
Mas a implementação IHttpClientFactory da Microsoft também pode ser usada para os melhores e mais recentes:
O RestClient.Net leva em consideração a injeção de dependência, a zombaria, os contêineres de IoC, a testabilidade da unidade e, acima de tudo, é rápido. Eu procurei e o único outro cliente que parece funcionar em uma capacidade semelhante é o Flurl.Http
fonte
O primeiro passo é criar a classe auxiliar para o cliente http.
Então você pode usar esta classe no seu código.
este é um exemplo de como você chama a API restante sem portador usando a classe acima.
este é um exemplo de como você pode chamar a API restante que requer portadora.
você também pode consultar o repositório abaixo se quiser ver o exemplo de funcionamento de como ele funciona.
https://github.com/mokh223/callApi
fonte