Создание почтового запроса вызывает nullpointerexception

Я пытаюсь сделать запрос на HttpClient.execute из одного из моих приложений для Android, но по HttpClient.execute то HttpClient.execute метод HttpClient.execute по какой-либо причине.

В моем приложении у меня есть метод makePostRequest, который я использую для создания почтовых запросов. Способ заключается в следующем:

// Makes a post request to the server
public void makePostRequest(String url, ArrayList<*************> postData) {
 HttpClient client = new DefaultHttpClient();
 HttpPost postRequest = new HttpPost();

 try {
 boolean prnull = postRequest == null;
 Log.d("DEBUG:", String.valueOf(prnull));
 postRequest.setEntity(new UrlEncodedFormEntity(postData));
 HttpResponse response = client.execute(postRequest);
 Log.i("INFO:", response.toString());
 } catch (ClientProtocolException e) {
 Log.d("DEBUG:", e.toString());
 } catch (IOException e) {
 Log.d("DEBUG:", e.toString());
 }

}
</*************>

и в своей деятельности я использую это как:

// Process user registration
 Button registerButton = (Button) findViewById(R.id.registerButton);
 registerButton.setOnClickListener(new View.OnClickListener() {

 @Override
 public void onClick(View v) {
 ArrayList<*************> postData = new ArrayList<*************>(2);
 postData.add(new ******************("email", "[removed_email]"));
 postData.add(new ******************("password", "abcdxyz"));
 makePostRequest(register_url, postData);
 }
 });
</*************></*************>

Ниже приведена таблица stacktrace:

05-13 06:12:55.888: E/AndroidRuntime(21553): FATAL EXCEPTION: main
05-13 06:12:55.888: E/AndroidRuntime(21553): Process: com.example.unishots, PID: 21553
05-13 06:12:55.888: E/AndroidRuntime(21553): java.lang.NullPointerException
05-13 06:12:55.888: E/AndroidRuntime(21553): at org.apache.http.impl.client.AbstractHttpClient.determineTarget(AbstractHttpClient.java:496)
05-13 06:12:55.888: E/AndroidRuntime(21553): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:487)
05-13 06:12:55.888: E/AndroidRuntime(21553): at org.apache.http.impl.client.AbstractHttpClient.execute(AbstractHttpClient.java:465)
05-13 06:12:55.888: E/AndroidRuntime(21553): at com.example.unishots.ShotsActivity.makePostRequest(ShotsActivity.java:61)
05-13 06:12:55.888: E/AndroidRuntime(21553): at com.example.unishots.RegisterActivity$2.onClick(RegisterActivity.java:42)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.view.View.performClick(View.java:4633)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.view.View$PerformClick.run(View.java:19330)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.os.Handler.handleCallback(Handler.java:733)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.os.Handler.dispatchMessage(Handler.java:95)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.os.Looper.loop(Looper.java:157)
05-13 06:12:55.888: E/AndroidRuntime(21553): at android.app.ActivityThread.main(ActivityThread.java:5356)
05-13 06:12:55.888: E/AndroidRuntime(21553): at java.lang.reflect.Method.invokeNative(Native Method)
05-13 06:12:55.888: E/AndroidRuntime(21553): at java.lang.reflect.Method.invoke(Method.java:515)
05-13 06:12:55.888: E/AndroidRuntime(21553): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1265)
05-13 06:12:55.888: E/AndroidRuntime(21553): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1081)
05-13 06:12:55.888: E/AndroidRuntime(21553): at dalvik.system.NativeStart.main(Native Method)

Я уже проверял, что postRequest не является нулевым, поскольку это единственный аргумент, переданный методу execute. Что может быть здесь неправильно?

Обновить

URL-адреса определяются как String-переменные в классе ShotsActivity который распространяется RegisterActivity. URL-адреса определяются следующим образом:

// Server url variables
public String base_url = "http://192.168.2.8:8000";
public String login_url = base_url + "/login/";
public String register_url = base_url + "/api/v1/users";
1 ответ

Я думаю, проблема заключается в том, что, хотя вы передаете свой строковый URL-адрес в makePostRequest(), вы его не используете нигде. Возможно, вы должны передать его HttpPost (url)

licensed under cc by-sa 3.0 with attribution.