我正在向带有两个参数的php服务器发送一条POST消息,一个是Base64中的HASH。 Base64使用字符“=”作为填充,因此它可以出现在哈希值中。
public void postData() {
// Create a new HttpClient and Post Header
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost("http://www.yoursite.com/script.php");
try {
// Add your data
List<NameValuePair> nameValuePairs = new ArrayList<NameValuePair>(2);
nameValuePairs.add(new BasicNameValuePair("id", "WAFFTE="));
nameValuePairs.add(new BasicNameValuePair("stringdata", "data"));
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs));
// Execute HTTP Post Request
HttpResponse response = httpclient.execute(httppost);
} catch (ClientProtocolException e) {
// TODO Auto-generated catch block
} catch (IOException e) {
// TODO Auto-generated catch block
}
}
使用此代码,url通过%3D编码“=”,但在这种情况下,服务器不会重新计算id值。我尝试过selectinf不同的编码,但没有区别。
httppost.setEntity(new UrlEncodedFormEntity(nameValuePairs),"UTF-8");
任何帮助?
答案 0 :(得分:0)
显然没有必要从post参数中删除“=”,但建议避免与分隔符混淆。所以最好使用Base64编码中的标志URL_SAFE和NO_PADDING。
我希望这可以帮助其他人解决同样的问题。