C#、asp.net访问基于http basic验证的api原理
2007-08-25 19:32
766 查看
注意引入命名空间
using System.Net;
using System.Text;
using System.IO;
具体核心代码:
WebRequest wr = WebRequest.Create(rssurl);//其中rssurl为要调用的api地址
wr.Method = "POST";指定调用方式get post
wr.ContentType = "application/x-www-form-urlencoded";
NetworkCredential nc = new NetworkCredential("username", "password", "");
wr.Credentials = nc;//传入httpbasic验证的用户名、密码
string data="";//传入需要给api的参数
StringBuilder UrlEncoded = new StringBuilder();
byte[] SomeBytes = null;
if (data != null)
{
ASCIIEncoding encodedData=new ASCIIEncoding();
SomeBytes=encodedData.GetBytes(data);
wr.ContentLength = SomeBytes.Length;
Stream newStream = wr.GetRequestStream();
newStream.Write(SomeBytes, 0, SomeBytes.Length);
newStream.Close();
}
else
{
wr.ContentLength = 0;
}
string re = "";
try
{
WebResponse result = wr.GetResponse();
Stream ReceiveStream = result.GetResponseStream();
Byte[] read = new Byte[512];
int bytes = ReceiveStream.Read(read, 0, 512);
re = "";
while (bytes > 0)
{
// 注意:
// 下面假定响应使用 UTF-8 作为编码方式。
// 如果内容以 ANSI 代码页形式(例如,932)发送,则使用类似下面的语句:
// Encoding encode = System.Text.Encoding.GetEncoding("shift-jis");
Encoding encode = System.Text.Encoding.GetEncoding("gb2312");
re += encode.GetString(read, 0, bytes);
bytes = ReceiveStream.Read(read, 0, 512);
}
}
catch (Exception e)
{
re = e.Message;
}
return re;
using System.Net;
using System.Text;
using System.IO;
具体核心代码:
WebRequest wr = WebRequest.Create(rssurl);//其中rssurl为要调用的api地址
wr.Method = "POST";指定调用方式get post
wr.ContentType = "application/x-www-form-urlencoded";
NetworkCredential nc = new NetworkCredential("username", "password", "");
wr.Credentials = nc;//传入httpbasic验证的用户名、密码
string data="";//传入需要给api的参数
StringBuilder UrlEncoded = new StringBuilder();
byte[] SomeBytes = null;
if (data != null)
{
ASCIIEncoding encodedData=new ASCIIEncoding();
SomeBytes=encodedData.GetBytes(data);
wr.ContentLength = SomeBytes.Length;
Stream newStream = wr.GetRequestStream();
newStream.Write(SomeBytes, 0, SomeBytes.Length);
newStream.Close();
}
else
{
wr.ContentLength = 0;
}
string re = "";
try
{
WebResponse result = wr.GetResponse();
Stream ReceiveStream = result.GetResponseStream();
Byte[] read = new Byte[512];
int bytes = ReceiveStream.Read(read, 0, 512);
re = "";
while (bytes > 0)
{
// 注意:
// 下面假定响应使用 UTF-8 作为编码方式。
// 如果内容以 ANSI 代码页形式(例如,932)发送,则使用类似下面的语句:
// Encoding encode = System.Text.Encoding.GetEncoding("shift-jis");
Encoding encode = System.Text.Encoding.GetEncoding("gb2312");
re += encode.GetString(read, 0, bytes);
bytes = ReceiveStream.Read(read, 0, 512);
}
}
catch (Exception e)
{
re = e.Message;
}
return re;
相关文章推荐
- C#、asp.net访问基于http basic验证的api原理
- asp.net Forms身份验证和基于角色的权限访问
- [转载]Asp.net(C#)中基于Forms验证的角色(用户组)验证授权过程
- ASP.NET基于表单的验证实现网上安全访问,管理(1)
- 在ASP.NET中如何用C#.NET实现基于表单的验证
- 如何使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- 如何使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- [导入]如何使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- ASP.NET基于表单的验证实现网上安全访问,管理
- 在ASP.NET中如何用C#.NET实现基于表单的验证
- asp.net登录 用Forms身份验证和基于角色的分目录访问
- 如何使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- asp.net Forms身份验证和基于角色的权限访问
- 使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- 使用 C# .NET 在 ASP.NET 应用程序中实现基于窗体的身份验证
- 在ASP.NET中如何用C#.NET实现基于表单的验证
- Asp.net中基于Forms验证的角色验证授权[原理及流程]
- 在ASP.NET中如何用C#.NET实现基于表单的验证
- 在ASP.NET中如何用C#.NET实现基于表单的验证
- ASP.NET基于表单的验证实现网上安全访问,管理(2)