记录一次脑子不清醒的通信——HTTP&&AES
C#利用HttpWebRequest与Stream进行POST数据测试&&AES加密
返回码:400
1.首先上传代码如下:
try
{
string SendMessageAddress = url;//请求链接
HttpWebRequest request = (HttpWebRequest)WebRequest.Create(SendMessageAddress);
request.Method = "POST";
request.AllowAutoRedirect = true;
request.Timeout = 1000;//此处自行设置
request.ContentType = "########";
string PostData = data;//请求参数
byte[] byteArray = Encoding.Default.GetBytes(PostData);
request.ContentLength = byteArray.Length;
using (Stream newStream = request.GetRequestStream())
{
newStream.Write(byteArray, 0, byteArray.Length);//写入参数
newStream.Close();
}
HttpWebResponse response = (HttpWebResponse)request.GetResponse();
Stream rspStream = response.GetResponseStream();
using (StreamReader reader = new StreamReader(rspStream, Encoding.UTF8))
{
htmlAll = reader.ReadToEnd();
rspStream.Close();
}
response.Close();
}
catch (Exception ex)
{
string s = ex.Message;
return s;
}
在Stream newStream = request.GetRequestStream()报错,流不可读,网上查阅了很多资料,大概有两种解决方案:
(1)用StreamReader 代替Stream ;
(2)用MemoryStream;
然而这次是因为数据库的数据已经存上去了,服务器设置了相关验证,如果数据已经存在,第二次Post是不允许的。
一把辛酸血泪史。。。。。。。。。。。
AES加密ECB模式,PKCS5Padding
由于服务端用java开发,客户端采用C#开发,不同语言间处理方式不同。我做的是客户端C#将Json形式的字符串进行AES加密,然后上传,因为Json.ToString()后有“\r\n”,而java貌似只有“\n”,所以导致加密后的数据无法解密,太惨了。