我要如何将一个字符串数据 (JSONObject.toString()
) 发送到一个 URL 上。我想在一个工具类中编写一个静态方法来完成此操作。我希望该方法签名如下
public static String postData (String url, String postData) throws SomeCustomException
应该如何格式化字符串 URL
返回的字符串是服务器响应的 JSON 数据的字符串表示形式。
编辑
现有的连接工具
package my.package;
import my.package.exceptions.CustomException;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.URLDecoder;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.DefaultHttpClient;
public class ConnectionUtil {
public static String postData(String url, String postData)
throws CustomException {
// Create a new HttpClient and Post Header
InputStream is = null;
StringBuilder sb = null;
String result = "";
HttpClient httpclient = new DefaultHttpClient();
HttpPost httppost = new HttpPost();
httppost.setHeader("host", url);
Log.v("ConnectionUtil", "Opening POST connection to URI = " + httppost.getURI() + " url = " + URLDecoder.decode(url));
try {
httppost.setEntity(new StringEntity(postData));
// Execute HTTP Post Request
HttpResponse response = httpclient.execute(httppost);
HttpEntity entity = response.getEntity();
is = entity.getContent();
} catch (Exception e) {
Log.e("log_tag", "Error in http connection " + e.toString());
e.printStackTrace();
throw new CustomException("Could not establish network connection");
}
try {
BufferedReader reader = new BufferedReader(new InputStreamReader(
is, "utf-8"), 8);
sb = new StringBuilder();
sb.append(reader.readLine() + "\n");
String line = "0";
while ((line = reader.readLine()) != null) {
sb.append(line + "\n");
}
is.close();
result = sb.toString();
} catch (Exception e) {
Log.e("log_tag", "Error converting result " + e.toString());
throw new CustomException("Error parsing the response");
}
Log.v("ConnectionUtil", "Sent: "+postData);
Log.v("ConnectionUtil", "Got result "+result);
return result;
}
}
Logcat输出
10-16 11:27:27.287: E/log_tag(4935): http连接错误,java.lang.NullPointerException 10-16 11:27:27.287: W/System.err(4935): java.lang.NullPointerException 10-16 11:27:27.287: W/System.err(4935): 在org.apache.http.impl.client.AbstractHttpClient.determineTarget(AbstractHttpClient.java:496)处发生了异常 10-16 11:27:27.307: W/System.err(4935): 在org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在in.gharpay.zap.integration.ConnectionUtil.postData(ConnectionUtil.java:92)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在in.gharpay.zap.integration.ZapTransaction$1.doInBackground(ZapTransaction.java:54)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在in.gharpay.zap.integration.ZapTransaction$1.doInBackground(ZapTransaction.java:1)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在android.os.AsyncTask$2.call(AsyncTask.java:185)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:306)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在java.util.concurrent.FutureTask.run(FutureTask.java:138)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1088)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:581)处发生了异常 10-16 11:27:27.327: W/System.err(4935): 在java.lang.Thread.run(Thread.java:1019)处发生了异常 10-16 11:27:27.327: V/log_tag(4935): 无法建立网络连接