जावा - आसानी से POST विधि के माध्यम से HTTP मापदंडों को भेजना


319

मैं विधि के HTTPमाध्यम से कुछ मापदंडों के साथ अनुरोध भेजने के लिए इस कोड का सफलतापूर्वक उपयोग कर रहा हूं GET

void sendRequest(String request)
{
    // i.e.: request = "http://example.com/index.php?param1=a&param2=b&param3=c";
    URL url = new URL(request); 
    HttpURLConnection connection = (HttpURLConnection) url.openConnection();           
    connection.setDoOutput(true); 
    connection.setInstanceFollowRedirects(false); 
    connection.setRequestMethod("GET"); 
    connection.setRequestProperty("Content-Type", "text/plain"); 
    connection.setRequestProperty("charset", "utf-8");
    connection.connect();
}

अब मुझे POSTविधि के माध्यम से पैरामीटर (यानी param1, param2, param3) भेजने की आवश्यकता हो सकती है क्योंकि वे बहुत लंबे हैं। मैं उस पद्धति (यानी स्ट्रिंग httpMethod) में एक अतिरिक्त पैरामीटर जोड़ने के लिए सोच रहा था।

मैं ऊपर दिए गए कोड को कम से कम कैसे बदल सकता / सकती हूं ताकि GETया तो के माध्यम से या तो पैरामीटर्स भेज सके POST?

मैं उम्मीद कर रहा था कि बदल रहा है

connection.setRequestMethod("GET");

सेवा

connection.setRequestMethod("POST");

चाल चली होगी, लेकिन मापदंडों को अभी भी जीईटी विधि के माध्यम से भेजा जाता है।

गया है HttpURLConnectionकिसी भी विधि में मदद मिलेगी मिल गया? क्या कोई सहायक जावा निर्माण है?

किसी भी मदद को बहुत, बहुत सराहा जाएगा।


पोस्ट पैरामीटर को http हेडर सेक्शन के अंदर नहीं URL में भेजा जाता है। (आपकी पोस्ट url होगी http://example.com/index.php)
dacwe

2
कोई विधि सेट नहीं है Java 1.6 में निर्धारितमेस्टरथोड परिभाषित: docs.oracle.com/javase/6/docs/api/java/net/URLConnection.html
ante.sabo

2
इसे Http (यों) मूत्रलता के लिए कास्ट करें ...
पीटर

प्रश्न का विस्तार! क्या किसी को कोई सुराग है कि पोस्ट पैरामीटर के रूप में एक अनुलग्नक कैसे भेजा जाए ...
इसके

1
पहला कोड स्निपेट "फ़ंक्शन" कीवर्ड से क्यों शुरू होता है?
लेलेव वालिस

जवाबों:


470

GET अनुरोध में, पैरामीटर URL के भाग के रूप में भेजे जाते हैं।

एक पोस्ट अनुरोध में, हेडर के बाद मापदंडों को अनुरोध के एक निकाय के रूप में भेजा जाता है।

HttpURLConnection के साथ एक POST करने के लिए, कनेक्शन खोलने के बाद आपको कनेक्शन को पैरामीटर लिखना होगा।

यह कोड आपको आरंभ करना चाहिए:

String urlParameters  = "param1=a&param2=b&param3=c";
byte[] postData       = urlParameters.getBytes( StandardCharsets.UTF_8 );
int    postDataLength = postData.length;
String request        = "http://example.com/index.php";
URL    url            = new URL( request );
HttpURLConnection conn= (HttpURLConnection) url.openConnection();           
conn.setDoOutput( true );
conn.setInstanceFollowRedirects( false );
conn.setRequestMethod( "POST" );
conn.setRequestProperty( "Content-Type", "application/x-www-form-urlencoded"); 
conn.setRequestProperty( "charset", "utf-8");
conn.setRequestProperty( "Content-Length", Integer.toString( postDataLength ));
conn.setUseCaches( false );
try( DataOutputStream wr = new DataOutputStream( conn.getOutputStream())) {
   wr.write( postData );
}

40
@Alan Geleynse: 'url.openconnection ()' कनेक्शन नहीं खोलता है। मामले में आप एक कनेक्ट निर्दिष्ट नहीं करते हैं () जब आप http अनुरोध बॉडी को लिखते / सुनते हैं और इसे भेजते हैं तो कनेक्शन खोला जाता है। मैंने प्रमाण पत्रों के साथ यह कोशिश की है। Ssl handshake आपके कनेक्ट होने या सर्वर पर डेटा भेजने के बाद ही होता है।
अश्विन

14
getBytes () पर्यावरण के डिफ़ॉल्ट चारसेट का उपयोग करता है, न कि UTF-8 charset = utf-8 को सामग्री प्रकार को फ़ोल्व करना चाहिए: एप्लिकेशन / x-www-form-urlencoded, charset = utf-8 आप उदाहरण में दो बार बाइट रूपांतरण करते हैं। करना चाहिए: बाइट [] डेटा = urlParameters.getData ("UTF-8"); connection.getOutputStream () लिखने (डेटा)। बंद और फ्लश और डिस्कनेक्ट करने के लिए कोई उपयोग नहीं
पीटर क्रिएन्स

8
@PeterKriens आपके अतिरिक्त के लिए धन्यवाद - मेरा मानना ​​है कि आपका मतलब byte[] data = urlParameters.getBytes(Charset.forName("UTF-8")):) है।
गेरेटन

7
@AlanGeleynse क्या आपको wr.flush () याद नहीं है; और wr.close (); अतं मै?
मिलाप

9
यदि यह काम नहीं कर रहा है, तो इसके कितने उत्थान हैं? आपको conn.getResponseCode()या तो कॉल करने की आवश्यकता है या conn.getInputStream()अन्यथा यह कोई डेटा नहीं भेजेगा।
इमस्कर

229

यहां एक सरल उदाहरण है जो एक फॉर्म को सबमिट करता है और फिर परिणाम पृष्ठ को डंप करता है System.out। URL और POST को उपयुक्त रूप से बदलें, निश्चित रूप से:

import java.io.*;
import java.net.*;
import java.util.*;

class Test {
    public static void main(String[] args) throws Exception {
        URL url = new URL("http://example.net/new-message.php");
        Map<String,Object> params = new LinkedHashMap<>();
        params.put("name", "Freddie the Fish");
        params.put("email", "fishie@seamail.example.com");
        params.put("reply_to_thread", 10394);
        params.put("message", "Shark attacks in Botany Bay have gotten out of control. We need more defensive dolphins to protect the schools here, but Mayor Porpoise is too busy stuffing his snout with lobsters. He's so shellfish.");

        StringBuilder postData = new StringBuilder();
        for (Map.Entry<String,Object> param : params.entrySet()) {
            if (postData.length() != 0) postData.append('&');
            postData.append(URLEncoder.encode(param.getKey(), "UTF-8"));
            postData.append('=');
            postData.append(URLEncoder.encode(String.valueOf(param.getValue()), "UTF-8"));
        }
        byte[] postDataBytes = postData.toString().getBytes("UTF-8");

        HttpURLConnection conn = (HttpURLConnection)url.openConnection();
        conn.setRequestMethod("POST");
        conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
        conn.setRequestProperty("Content-Length", String.valueOf(postDataBytes.length));
        conn.setDoOutput(true);
        conn.getOutputStream().write(postDataBytes);

        Reader in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));

        for (int c; (c = in.read()) >= 0;)
            System.out.print((char)c);
    }
}

यदि आप Stringसीधे प्रिंट आउट के बजाय परिणाम चाहते हैं:

        StringBuilder sb = new StringBuilder();
        for (int c; (c = in.read()) >= 0;)
            sb.append((char)c);
        String response = sb.toString();

यह सबसे अच्छा उत्तर है क्योंकि इसमें पैरामीटर एन्कोडिंग और मैप का उपयोग शामिल है।
हवादार

4
दुर्भाग्य से यह कोड मानता है कि सामग्री का एन्कोडिंग है UTF-8, जो हमेशा ऐसा नहीं होता है। चारसेट को पुनः प्राप्त करने के लिए, हेडर प्राप्त करना चाहिए Content-Typeऔर उसी के चार्ट को पार्स करना चाहिए । जब वह शीर्ष लेख उपलब्ध नहीं होता है, तो मानक http एक का उपयोग करें ISO-8859-1:।
इंजीनियर

@ मूल्यांकन IFTFY ... मूल्यांकन में साइड इफेक्ट्स के साथ अभिव्यक्ति का उपयोग करना वास्तव में बदसूरत है।

1
HTML के लिए दुर्भाग्य से @engineercoding यह यह पूरी तरह से सही ढंग से करने के लिए और भी कठिन है कि तुलना में है, के रूप में वहाँ भी एक यूनिकोड बीओएम हो सकता है, या एक <meta charset="...">या <meta http-equiv="Content-Type" content="...">दस्तावेज है कि जरूरतों को पार्स किया जा सकता अंदर हैडर।
बोआन सिप

1
@ नेप्स्टर ऐसा मत करो। response += line;अभूतपूर्व रूप से धीमा है, और यह लाइन को तोड़ता है। मैंने उत्तर में स्ट्रिंग प्रतिक्रिया प्राप्त करने का एक उदाहरण जोड़ा है।
Boann

63

मुझे वास्तव में पोस्ट करने के लिए एलन का उदाहरण नहीं मिला , इसलिए मैंने इसे समाप्त किया:

String urlParameters = "param1=a&param2=b&param3=c";
URL url = new URL("http://example.com/index.php");
URLConnection conn = url.openConnection();

conn.setDoOutput(true);

OutputStreamWriter writer = new OutputStreamWriter(conn.getOutputStream());

writer.write(urlParameters);
writer.flush();

String line;
BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));

while ((line = reader.readLine()) != null) {
    System.out.println(line);
}
writer.close();
reader.close();         

1
दुर्भाग्य से, यह कोड प्रतिक्रिया नहीं पढ़ता है। यह खाली फॉर्म html को पढ़ता है।
कोवेक इमर्रे

मुझे एलन के उदाहरण से जो जोड़ना था वह प्रतिक्रिया प्रवाह खोल रहा था। इससे पहले कि मैं इसे किया था, वास्तव में कोई बाइट्स नहीं भेजे गए थे।
बीफदर

1
लेखक को हटाते हुए। क्लोज़ () कॉल ने मेरे लिए किया।
मैक्सिमे टी

23

मैं HttpURLConnectionवास्तव में उपयोग करने के लिए बोझिल लगता हूं । और आपको बहुत सारे बॉयलरप्लेट, एरर प्रोन कोड लिखना होगा। मुझे अपने एंड्रॉइड प्रोजेक्ट्स के लिए एक हल्के आवरण की आवश्यकता थी और एक पुस्तकालय के साथ बाहर आया, जिसे आप उपयोग कर सकते हैं: डेविडवेब

उपरोक्त उदाहरण इस तरह लिखा जा सकता है:

Webb webb = Webb.create();
webb.post("http://example.com/index.php")
        .param("param1", "a")
        .param("param2", "b")
        .param("param3", "c")
        .ensureSuccess()
        .asVoid();

आप दिए गए लिंक पर वैकल्पिक पुस्तकालयों की सूची पा सकते हैं।


1
मैं अपवित्र नहीं होने जा रहा हूं क्योंकि आपका पोस्ट एक उत्तर से कम और एक विज्ञापन का अधिक था ... लेकिन, मैंने आपकी लाइब्रेरी के साथ खेला और मुझे यह पसंद आया। बहुत रसीला; बहुत सारे सिंथेटिक चीनी; यदि आप जावा का उपयोग स्क्रिप्टिंग भाषा के एक बिट के रूप में करते हैं तो मैं करता हूं तो यह बहुत जल्दी और कुशलतापूर्वक कुछ http इंटरैक्शन को जोड़ने के लिए एक महान पुस्तकालय है। शून्य बॉयलरप्लेट कई बार मूल्यवान है और यह ओपी के लिए उपयोगी हो सकता है।
डीन

3
मैं उत्थान करूंगा। मैंने अपने एक ऐप में डेविडवेब का सफलतापूर्वक इस्तेमाल किया है, और ऐसा मैं दो और के लिए करूंगा और जल्द ही इसका विकास करूंगा। उपयोग करने के लिए बहुत आसान है।
विलियम टी। मलार्ड

आपको धन्यवाद, Android पर https के साथ DefaultHttpClient का उपयोग करना SSLPeerUnverifiedException के साथ विफल हो जाता है: कोई सहकर्मी प्रमाणपत्र (यहां तक ​​कि सही ढंग से हस्ताक्षरित https प्रमाणपत्रों पर), URL का उपयोग करना बोझिल है (एन्कोडिंग पैरामीटर, परिणाम की जांच करना)। डेविडवेब का उपयोग करते हुए मेरे लिए काम किया, धन्यवाद।
मार्टिन विसेनी

नहीं AsyncTask समर्थन? तो डिफ़ॉल्ट रूप से UI थ्रेड को लॉक करना ... यह बुरा है
16

यह बहुत बुनियादी पुस्तकालय है। प्रोग्रामर को बैकग्राउंड-थ्रेड से, AsyncTask में, IntentService में, सिंक्रोनाइज़ेशन हैंडलर और इसी तरह से कॉल करना है। और यह एंड्रॉइड पर निर्भर नहीं करता है -> जावा एसई और ईई में भी इस्तेमाल किया जा सकता है।
होगेंबल

12

मैंने ऊपर उत्तर पढ़े हैं और HTTP अनुरोध को सरल बनाने के लिए एक उपयोगिता वर्ग बनाया है। मुझे आशा है कि यह आपकी मदद करेगा।

विधि कॉल

  // send params with Hash Map
    HashMap<String, String> params = new HashMap<String, String>();
    params.put("email","me@example.com");
    params.put("password","12345");

    //server url
    String url = "http://www.example.com";

    // static class "HttpUtility" with static method "newRequest(url,method,callback)"
    HttpUtility.newRequest(url,HttpUtility.METHOD_POST,params, new HttpUtility.Callback() {
        @Override
        public void OnSuccess(String response) {
        // on success
           System.out.println("Server OnSuccess response="+response);
        }
        @Override
        public void OnError(int status_code, String message) {
        // on error
              System.out.println("Server OnError status_code="+status_code+" message="+message);
        }
    });

उपयोगिता वर्ग

import java.io.*;
import java.net.*;
import java.util.HashMap;
import java.util.Map;
import static java.net.HttpURLConnection.HTTP_OK;

public class HttpUtility {

 public static final int METHOD_GET = 0; // METHOD GET
 public static final int METHOD_POST = 1; // METHOD POST

 // Callback interface
 public interface Callback {
  // abstract methods
  public void OnSuccess(String response);
  public void OnError(int status_code, String message);
 }
 // static method
 public static void newRequest(String web_url, int method, HashMap < String, String > params, Callback callback) {

  // thread for handling async task
  new Thread(new Runnable() {
   @Override
   public void run() {
    try {
     String url = web_url;
     // write GET params,append with url
     if (method == METHOD_GET && params != null) {
      for (Map.Entry < String, String > item: params.entrySet()) {
       String key = URLEncoder.encode(item.getKey(), "UTF-8");
       String value = URLEncoder.encode(item.getValue(), "UTF-8");
       if (!url.contains("?")) {
        url += "?" + key + "=" + value;
       } else {
        url += "&" + key + "=" + value;
       }
      }
     }

     HttpURLConnection urlConnection = (HttpURLConnection) new URL(url).openConnection();
     urlConnection.setUseCaches(false);
     urlConnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded"); // handle url encoded form data
     urlConnection.setRequestProperty("charset", "utf-8");
     if (method == METHOD_GET) {
      urlConnection.setRequestMethod("GET");
     } else if (method == METHOD_POST) {
      urlConnection.setDoOutput(true); // write POST params
      urlConnection.setRequestMethod("POST");
     }

     //write POST data 
     if (method == METHOD_POST && params != null) {
      StringBuilder postData = new StringBuilder();
      for (Map.Entry < String, String > item: params.entrySet()) {
       if (postData.length() != 0) postData.append('&');
       postData.append(URLEncoder.encode(item.getKey(), "UTF-8"));
       postData.append('=');
       postData.append(URLEncoder.encode(String.valueOf(item.getValue()), "UTF-8"));
      }
      byte[] postDataBytes = postData.toString().getBytes("UTF-8");
      urlConnection.setRequestProperty("Content-Length", String.valueOf(postDataBytes.length));
      urlConnection.getOutputStream().write(postDataBytes);

     }
     // server response code
     int responseCode = urlConnection.getResponseCode();
     if (responseCode == HTTP_OK && callback != null) {
      BufferedReader reader = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
      StringBuilder response = new StringBuilder();
      String line;
      while ((line = reader.readLine()) != null) {
       response.append(line);
      }
      // callback success
      callback.OnSuccess(response.toString());
      reader.close(); // close BufferReader
     } else if (callback != null) {
      // callback error
      callback.OnError(responseCode, urlConnection.getResponseMessage());
     }

     urlConnection.disconnect(); // disconnect connection
    } catch (IOException e) {
     e.printStackTrace();
     if (callback != null) {
      // callback error
      callback.OnError(500, e.getLocalizedMessage());
     }
    }
   }
  }).start(); // start thread
 }
}

10

मुझे लगता है कि कुछ अन्य जवाबों ने विकल्प दिया है, मुझे व्यक्तिगत रूप से लगता है कि सहजता से आप सही काम कर रहे हैं;)। क्षमा करें, devoxx पर जहां कई वक्ता इस प्रकार की चीजों के बारे में बता रहे हैं।

यही कारण है कि मैं व्यक्तिगत रूप से इस तरह के काम करने के लिए Apache के HTTPClient / HttpCore पुस्तकालयों का उपयोग करता हूं, मुझे लगता है कि जावा के मूल HTTP समर्थन की तुलना में उनके एपीआई का उपयोग करना आसान है। YMMV बेशक!


10
import java.net.*;

public class Demo{

  public static void main(){

       String data = "data=Hello+World!";
       URL url = new URL("http://localhost:8084/WebListenerServer/webListener");
       HttpURLConnection con = (HttpURLConnection) url.openConnection();
       con.setRequestMethod("POST");
       con.setDoOutput(true);
       con.getOutputStream().write(data.getBytes("UTF-8"));
       con.getInputStream();

    }

}

5
WTH import java.net.*;!
यौषा अलायबॉ

4

मेरी भी यही समस्या थी। मैं POST के माध्यम से डेटा भेजना चाहता था। मैंने निम्नलिखित कोड का उपयोग किया:

    URL url = new URL("http://example.com/getval.php");
    Map<String,Object> params = new LinkedHashMap<>();
    params.put("param1", param1);
    params.put("param2", param2);

    StringBuilder postData = new StringBuilder();
    for (Map.Entry<String,Object> param : params.entrySet()) {
        if (postData.length() != 0) postData.append('&');
        postData.append(URLEncoder.encode(param.getKey(), "UTF-8"));
        postData.append('=');
        postData.append(URLEncoder.encode(String.valueOf(param.getValue()), "UTF-8"));
    }
    String urlParameters = postData.toString();
    URLConnection conn = url.openConnection();

    conn.setDoOutput(true);

    OutputStreamWriter writer = new OutputStreamWriter(conn.getOutputStream());

    writer.write(urlParameters);
    writer.flush();

    String result = "";
    String line;
    BufferedReader reader = new BufferedReader(new InputStreamReader(conn.getInputStream()));

    while ((line = reader.readLine()) != null) {
        result += line;
    }
    writer.close();
    reader.close()
    System.out.println(result);

मैंने पार्स के लिए Jsoup का उपयोग किया:

    Document doc = Jsoup.parseBodyFragment(value);
    Iterator<Element> opts = doc.select("option").iterator();
    for (;opts.hasNext();) {
        Element item = opts.next();
        if (item.hasAttr("value")) {
            System.out.println(item.attr("value"));
        }
    }

4

GET और POST विधि इस तरह सेट की जाती है ... एपीआई कॉलिंग के लिए दो प्रकार) 1) मिलता है () और 2) पोस्ट ()। हमारे डेटा पोस्ट में url में मूल्य और पोस्ट () विधि का उपयोग करने और प्रतिक्रिया प्राप्त करने के लिए एपीआई जसन सरणी से मूल्य प्राप्त करने के लिए विधि प्राप्त करें।

 public class HttpClientForExample {

    private final String USER_AGENT = "Mozilla/5.0";

    public static void main(String[] args) throws Exception {

        HttpClientExample http = new HttpClientExample();

        System.out.println("Testing 1 - Send Http GET request");
        http.sendGet();

        System.out.println("\nTesting 2 - Send Http POST request");
        http.sendPost();

    }

    // HTTP GET request
    private void sendGet() throws Exception {

        String url = "http://www.google.com/search?q=developer";

        HttpClient client = new DefaultHttpClient();
        HttpGet request = new HttpGet(url);

        // add request header
        request.addHeader("User-Agent", USER_AGENT);

        HttpResponse response = client.execute(request);

        System.out.println("\nSending 'GET' request to URL : " + url);
        System.out.println("Response Code : " + 
                       response.getStatusLine().getStatusCode());

        BufferedReader rd = new BufferedReader(
                       new InputStreamReader(response.getEntity().getContent()));

        StringBuffer result = new StringBuffer();
        String line = "";
        while ((line = rd.readLine()) != null) {
            result.append(line);
        }

        System.out.println(result.toString());

    }

    // HTTP POST request
    private void sendPost() throws Exception {

        String url = "https://selfsolve.apple.com/wcResults.do";

        HttpClient client = new DefaultHttpClient();
        HttpPost post = new HttpPost(url);

        // add header
        post.setHeader("User-Agent", USER_AGENT);

        List<NameValuePair> urlParameters = new ArrayList<NameValuePair>();
        urlParameters.add(new BasicNameValuePair("sn", "C02G8416DRJM"));
        urlParameters.add(new BasicNameValuePair("cn", ""));
        urlParameters.add(new BasicNameValuePair("locale", ""));
        urlParameters.add(new BasicNameValuePair("caller", ""));
        urlParameters.add(new BasicNameValuePair("num", "12345"));

        post.setEntity(new UrlEncodedFormEntity(urlParameters));

        HttpResponse response = client.execute(post);
        System.out.println("\nSending 'POST' request to URL : " + url);
        System.out.println("Post parameters : " + post.getEntity());
        System.out.println("Response Code : " + 
                                    response.getStatusLine().getStatusCode());

        BufferedReader rd = new BufferedReader(
                        new InputStreamReader(response.getEntity().getContent()));

        StringBuffer result = new StringBuffer();
        String line = "";
        while ((line = rd.readLine()) != null) {
            result.append(line);
        }

        System.out.println(result.toString());

    }

}

3

इस पैटर्न को आज़माएं:

public static PricesResponse getResponse(EventRequestRaw request) {

    // String urlParameters  = "param1=a&param2=b&param3=c";
    String urlParameters = Piping.serialize(request);

    HttpURLConnection conn = RestClient.getPOSTConnection(endPoint, urlParameters);

    PricesResponse response = null;

    try {
        // POST
        OutputStreamWriter writer = new OutputStreamWriter(conn.getOutputStream());
        writer.write(urlParameters);
        writer.flush();

        // RESPONSE
        BufferedReader reader = new BufferedReader(new InputStreamReader((conn.getInputStream()), StandardCharsets.UTF_8));
        String json = Buffering.getString(reader);
        response = (PricesResponse) Piping.deserialize(json, PricesResponse.class);

        writer.close();
        reader.close();

    } catch (Exception e) {
        e.printStackTrace();
    }

    conn.disconnect();

    System.out.println("PricesClient: " + response.toString());

    return response;
}

public static HttpURLConnection getPOSTConnection(String endPoint, String urlParameters) {

    return RestClient.getConnection(endPoint, "POST", urlParameters);

}


public static HttpURLConnection getConnection(String endPoint, String method, String urlParameters) {

    System.out.println("ENDPOINT " + endPoint + " METHOD " + method);
    HttpURLConnection conn = null;

    try {
        URL url = new URL(endPoint);
        conn = (HttpURLConnection) url.openConnection();
        conn.setRequestMethod(method);
        conn.setDoOutput(true);
        conn.setRequestProperty("Content-Type", "text/plain");

    } catch (IOException e) {
        e.printStackTrace();
    }

    return conn;
}

3

यह उत्तर कस्टम जावा POJO का उपयोग करके POST कॉल के विशिष्ट मामले को कवर करता है।

हमारे जावा ऑब्जेक्ट को JSON के लिए अनुक्रमित करने के लिए Gson के लिए मावेन निर्भरता का उपयोग करना ।

नीचे निर्भरता का उपयोग करके Gson स्थापित करें।

<dependency>
  <groupId>com.google.code.gson</groupId>
  <artifactId>gson</artifactId>
  <version>2.8.5</version>
  <scope>compile</scope>
</dependency>

नीचे का उपयोग करने वालों के लिए नीचे का उपयोग कर सकते हैं

dependencies {
implementation 'com.google.code.gson:gson:2.8.5'
}

उपयोग किए गए अन्य आयात:

import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.*;
import org.apache.http.impl.client.CloseableHttpClient;
import com.google.gson.Gson;

अब, हम आगे बढ़ सकते हैं और अपाचे द्वारा प्रदान किए गए HttpPost का उपयोग कर सकते हैं

private CloseableHttpClient httpclient = HttpClients.createDefault();
HttpPost httppost = new HttpPost("https://example.com");

Product product = new Product(); //custom java object to be posted as Request Body
    Gson gson = new Gson();
    String client = gson.toJson(product);

    httppost.setEntity(new StringEntity(client, ContentType.APPLICATION_JSON));
    httppost.setHeader("RANDOM-HEADER", "headervalue");
    //Execute and get the response.
    HttpResponse response = null;
    try {
        response = httpclient.execute(httppost);
    } catch (IOException e) {
        throw new InternalServerErrorException("Post fails");
    }
    Response.Status responseStatus = Response.Status.fromStatusCode(response.getStatusLine().getStatusCode());
    return Response.status(responseStatus).build();

उपरोक्त कोड POST कॉल से प्राप्त प्रतिक्रिया कोड के साथ वापस आ जाएगा


2

यहाँ मैंने पैरामीटर के रूप में jsonobject भेजा // jsonobject = {"name": "lucifer", "पास": "abc"} // serverUrl = " http://192.168.100.12/testing " //host=19.1.1.1.1.1.1.12।

  public static String getJson(String serverUrl,String host,String jsonobject){

    StringBuilder sb = new StringBuilder();

    String http = serverUrl;

    HttpURLConnection urlConnection = null;
    try {
        URL url = new URL(http);
        urlConnection = (HttpURLConnection) url.openConnection();
        urlConnection.setDoOutput(true);
        urlConnection.setRequestMethod("POST");
        urlConnection.setUseCaches(false);
        urlConnection.setConnectTimeout(50000);
        urlConnection.setReadTimeout(50000);
        urlConnection.setRequestProperty("Content-Type", "application/json");
        urlConnection.setRequestProperty("Host", host);
        urlConnection.connect();
        //You Can also Create JSONObject here 
        OutputStreamWriter out = new OutputStreamWriter(urlConnection.getOutputStream());
        out.write(jsonobject);// here i sent the parameter
        out.close();
        int HttpResult = urlConnection.getResponseCode();
        if (HttpResult == HttpURLConnection.HTTP_OK) {
            BufferedReader br = new BufferedReader(new InputStreamReader(
                    urlConnection.getInputStream(), "utf-8"));
            String line = null;
            while ((line = br.readLine()) != null) {
                sb.append(line + "\n");
            }
            br.close();
            Log.e("new Test", "" + sb.toString());
            return sb.toString();
        } else {
            Log.e(" ", "" + urlConnection.getResponseMessage());
        }
    } catch (MalformedURLException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    } catch (JSONException e) {
        e.printStackTrace();
    } finally {
        if (urlConnection != null)
            urlConnection.disconnect();
    }
    return null;
}

2

मैं अपाचे http एपीआई पर निर्मित http-request को higly recomend करता हूं ।

अपने मामले के लिए आप उदाहरण देख सकते हैं:

private static final HttpRequest<String.class> HTTP_REQUEST = 
      HttpRequestBuilder.createPost("http://example.com/index.php", String.class)
           .responseDeserializer(ResponseDeserializer.ignorableDeserializer())
           .build();

public void sendRequest(String request){
     String parameters = request.split("\\?")[1];
     ResponseHandler<String> responseHandler = 
            HTTP_REQUEST.executeWithQuery(parameters);

   System.out.println(responseHandler.getStatusCode());
   System.out.println(responseHandler.get()); //prints response body
}

यदि आप प्रतिक्रिया निकाय में रुचि नहीं रखते हैं

private static final HttpRequest<?> HTTP_REQUEST = 
     HttpRequestBuilder.createPost("http://example.com/index.php").build();

public void sendRequest(String request){
     ResponseHandler<String> responseHandler = 
           HTTP_REQUEST.executeWithQuery(parameters);
}

Http- request के साथ सामान्य रूप से पोस्ट अनुरोध भेजने के लिए : प्रलेखन पढ़ें और जावा में JSON स्ट्रिंग के साथ HTTP POST अनुरोध देखें, HTTP POST अनुरोध जावा में भेजना , HTTP POST जावा में JSON का उपयोग करना


1

नमस्कार pls इस पोस्ट का उपयोग अपनी पोस्ट विधि को बेहतर बनाने के लिए करें

public static JSONObject doPostRequest(HashMap<String, String> data, String url) {

    try {
        RequestBody requestBody;
        MultipartBuilder mBuilder = new MultipartBuilder().type(MultipartBuilder.FORM);

        if (data != null) {


            for (String key : data.keySet()) {
                String value = data.get(key);
                Utility.printLog("Key Values", key + "-----------------" + value);

                mBuilder.addFormDataPart(key, value);

            }
        } else {
            mBuilder.addFormDataPart("temp", "temp");
        }
        requestBody = mBuilder.build();


        Request request = new Request.Builder()
                .url(url)
                .post(requestBody)
                .build();

        OkHttpClient client = new OkHttpClient();
        Response response = client.newCall(request).execute();
        String responseBody = response.body().string();
        Utility.printLog("URL", url);
        Utility.printLog("Response", responseBody);
        return new JSONObject(responseBody);

    } catch (UnknownHostException | UnsupportedEncodingException e) {

        JSONObject jsonObject=new JSONObject();

        try {
            jsonObject.put("status","false");
            jsonObject.put("message",e.getLocalizedMessage());
        } catch (JSONException e1) {
            e1.printStackTrace();
        }
        Log.e(TAG, "Error: " + e.getLocalizedMessage());
    } catch (Exception e) {
        e.printStackTrace();
        JSONObject jsonObject=new JSONObject();

        try {
            jsonObject.put("status","false");
            jsonObject.put("message",e.getLocalizedMessage());
        } catch (JSONException e1) {
            e1.printStackTrace();
        }
        Log.e(TAG, "Other Error: " + e.getLocalizedMessage());
    }
    return null;
}

0

मैंने Boann के उत्तर को लिया और इसे और अधिक लचीली क्वेरी स्ट्रिंग बिल्डर बनाने के लिए उपयोग किया, जो php के http_build_query विधि की तरह सूचियों और सरणियों का समर्थन करता है:

public static byte[] httpBuildQueryString(Map<String, Object> postsData) throws UnsupportedEncodingException {
    StringBuilder postData = new StringBuilder();
    for (Map.Entry<String,Object> param : postsData.entrySet()) {
        if (postData.length() != 0) postData.append('&');

        Object value = param.getValue();
        String key = param.getKey();

        if(value instanceof Object[] || value instanceof List<?>)
        {
            int size = value instanceof Object[] ? ((Object[])value).length : ((List<?>)value).size();
            for(int i = 0; i < size; i++)
            {
                Object val = value instanceof Object[] ? ((Object[])value)[i] : ((List<?>)value).get(i);
                if(i>0) postData.append('&');
                postData.append(URLEncoder.encode(key + "[" + i + "]", "UTF-8"));
                postData.append('=');            
                postData.append(URLEncoder.encode(String.valueOf(val), "UTF-8"));
            }
        }
        else
        {
            postData.append(URLEncoder.encode(key, "UTF-8"));
            postData.append('=');            
            postData.append(URLEncoder.encode(String.valueOf(value), "UTF-8"));
        }
    }
    return postData.toString().getBytes("UTF-8");
}

0

$ _POST का उपयोग करके php पेज पर अनुरोध प्राप्त करने में परेशानी वाले लोगों के लिए, क्योंकि आपको कुंजी-मूल्य वाले जोड़े की उम्मीद है:

हालांकि सभी उत्तर जहां बहुत उपयोगी थे, मुझे कुछ बुनियादी समझ की कमी थी, जिस पर वास्तव में पोस्ट करने के लिए स्ट्रिंग थी, क्योंकि पुराने अपाचे HttpClass में मैंने इस्तेमाल किया था

new UrlEncodedFormEntity(nameValuePairs); (Java)

और उसके बाद $ _POST का उपयोग php में की-वैल्यू जोड़े के लिए किया जा सकता है।

मेरी समझ से अब किसी ने पोस्ट करने से पहले मैन्युअल रूप से उस स्ट्रिंग का निर्माण किया है। तो स्ट्रिंग को देखने की जरूरत है

val data = "key1=val1&key2=val2"

लेकिन केवल इसे url में जोड़ने के बजाय इसे (हेडर में) पोस्ट किया जाता है।

विकल्प इसके बजाय एक json-string का उपयोग करना होगा:

val data = "{\"key1\":\"val1\",\"key2\":\"val2\"}" // {"key1":"val1","key2":"val2"}

और $ _POST के बिना php में इसे खींचें:

$json_params = file_get_contents('php://input');
// echo_p("Data: $json_params");
$data = json_decode($json_params, true);

यहाँ आपको कोटलिन में एक नमूना कोड मिलता है:

class TaskDownloadTest : AsyncTask<Void, Void, Void>() {
    override fun doInBackground(vararg params: Void): Void? {
        var urlConnection: HttpURLConnection? = null

        try {

            val postData = JsonObject()
            postData.addProperty("key1", "val1")
            postData.addProperty("key2", "val2")

            // reformat json to key1=value1&key2=value2
            // keeping json because I may change the php part to interpret json requests, could be a HashMap instead
            val keys = postData.keySet()
            var request = ""
            keys.forEach { key ->
                // Log.i("data", key)
                request += "$key=${postData.get(key)}&"
            }
            request = request.replace("\"", "").removeSuffix("&")
            val requestLength = request.toByteArray().size
            // Warning in Android 9 you need to add a line in the application part of the manifest: android:usesCleartextTraffic="true"
            // /programming/45940861/android-8-cleartext-http-traffic-not-permitted
            val url = URL("http://10.0.2.2/getdata.php")
            urlConnection = url.openConnection() as HttpURLConnection
            // urlConnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded") // apparently default
            // Not sure what these are for, I do not use them
            // urlConnection.setRequestProperty("Content-Type", "application/json")
            // urlConnection.setRequestProperty("Key","Value")
            urlConnection.readTimeout = 5000
            urlConnection.connectTimeout = 5000
            urlConnection.requestMethod = "POST"
            urlConnection.doOutput = true
            // urlConnection.doInput = true
            urlConnection.useCaches = false
            urlConnection.setFixedLengthStreamingMode(requestLength)
            // urlConnection.setChunkedStreamingMode(0) // if you do not want to handle request length which is fine for small requests

            val out = urlConnection.outputStream
            val writer = BufferedWriter(
                OutputStreamWriter(
                    out, "UTF-8"
                )
            )
            writer.write(request)
            // writer.write("{\"key1\":\"val1\",\"key2\":\"val2\"}") // {"key1":"val1","key2":"val2"} JsonFormat or just postData.toString() for $json_params=file_get_contents('php://input'); json_decode($json_params, true); in php
            // writer.write("key1=val1&key2=val2") // key=value format for $_POST in php
            writer.flush()
            writer.close()
            out.close()

            val code = urlConnection.responseCode
            if (code != 200) {
                throw IOException("Invalid response from server: $code")
            }

            val rd = BufferedReader(
                InputStreamReader(
                    urlConnection.inputStream
                )
            )
            var line = rd.readLine()
            while (line != null) {
                Log.i("data", line)
                line = rd.readLine()
            }
        } catch (e: Exception) {
            e.printStackTrace()
        } finally {
            urlConnection?.disconnect()
        }

        return null
    }
}

-3

प्रकट होता है कि आपको connection.getOutputStream()"कम से कम एक बार" (साथ ही साथ) कॉल करना होगाsetDoOutput(true) ) इसके लिए एक POST के रूप में मानना ​​होगा।

तो न्यूनतम आवश्यक कोड है:

    URL url = new URL(urlString);
    HttpURLConnection connection = (HttpURLConnection) url.openConnection();
    //connection.setRequestMethod("POST"); this doesn't seem to do anything at all..so not useful
    connection.setDoOutput(true); // set it to POST...not enough by itself however, also need the getOutputStream call...
    connection.connect();
    connection.getOutputStream().close(); 

आप आश्चर्यजनक रूप से, urlString में "GET" शैली मापदंडों का उपयोग कर सकते हैं। हालांकि वह चीजों को भ्रमित कर सकता है।

आप जाहिरा तौर पर NameValuePair का भी उपयोग कर सकते हैं ।


POST पैरामीटर कहाँ हैं ...?
युषा अलायूब

लोग इसे क्यों कम कर रहे हैं? यह बिना किसी पैरामीटर के, हालांकि POST को कैसे करना है, इसके लिए एक नोट है ... (यानी कोई पेलोड 0 ...
'23
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.