दिलचस्प पोस्ट
क्या एक रिमोट रिपॉजिटरी में एक git छिपाने की जगह धक्का संभव है? तत्काल = "सच्चा" को समझने की कोशिश कर रहा है जब यह नहीं होना चाहिए मुझे किस बात का पता चल सकता है कि किसने बल को गिट में धकेल दिया? मौजूदा एएसआईएन के साथ आइटम के लिए सही अमेज़ॅन मेगावाट का प्रवाह जावास्क्रिप्ट इनहेरिटन्स क्यों इस कार्यक्रम को "फोर्क किया गया" प्रिंट करता है? 4 बार? SQL सर्वर क्वेरी – DISTINCT के साथ COUNT (*) का चयन करना मैं मोचा और चाय के साथ कैसे सही तरीके से परीक्षण करता हूं? स्ट्रिंग को यूटीएफ -8 में एन्कोड करें मैं Safari / Chrome में जावास्क्रिप्ट से एक आइफ्रेम कैसे प्रिंट करूं? getopt पैरामीटर के लिए वैकल्पिक तर्क को पार्स नहीं करता है PHP में समय अपलोड अपलोड कर सकता है? NSXMLParser: गैर- ASCII वर्णों के साथ अनपेक्षित परिणाम एचटीएमएल / सीएसएस द्वारा क्रोम / सफारी वर्तनी की जांच बंद करें रेल सर्वर बिन / रेल: 6: चेतावनी: पहले से ही आरम्भ किए गए निरंतर APP_PATH त्रुटि

वॉली के साथ और एचटीपीटीटीटी के बिना काम करने वाले डाक बहुपयोगी अनुरोध

यह वास्तव में एक सवाल नहीं है, हालांकि, मैं अपने संदर्भ के लिए यहां अपने कुछ कामकाजी कोड को यहां साझा करना चाहूंगा जब आपको आवश्यकता होती है।

जैसा कि हम जानते हैं कि एचपीटीएनटीआई एपीआई 22 से पदावनत है और एपीपी 23 के बाद से कॉमेलेली हटाई गई है। फिलहाल, हम अब एंड्रॉइड डेवलपर पर एचटीटीपीटीईटीई संदर्भ का उपयोग नहीं कर सकते (404)। इसलिए, निम्नलिखित मेरे कामकाजी नमूना कोड वोली के साथ और बिना HttpEntity के लिए बहुभाषी पोस्ट के लिए है। यह काम कर रहा है, Asp.Net Web API साथ परीक्षण किया गया Asp.Net Web API । बेशक, यह कोड सिर्फ एक बुनियादी नमूना है, जो दो चित्रों को छोड़ने योग्य फ़ाइलें पोस्ट करता है, यह भी सभी मामलों के लिए सबसे अच्छा समाधान नहीं है, और अच्छा ट्यूनिंग नहीं है।

बेहतर / अधिक सुंदर कोड के लिए कोई सुझाव की सराहना की जाएगी।

उम्मीद है की यह मदद करेगा!

MultipartActivity.java:

 package com.example.multipartvolley; import android.app.Activity; import android.content.Context; import android.graphics.Bitmap; import android.graphics.drawable.BitmapDrawable; import android.graphics.drawable.Drawable; import android.os.Bundle; import android.support.v4.content.ContextCompat; import android.view.Menu; import android.view.MenuItem; import android.widget.Toast; import com.android.volley.NetworkResponse; import com.android.volley.Response; import com.android.volley.VolleyError; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.DataOutputStream; import java.io.IOException; public class MultipartActivity extends Activity { private final Context context = this; private final String twoHyphens = "--"; private final String lineEnd = "\r\n"; private final String boundary = "apiclient-" + System.currentTimeMillis(); private final String mimeType = "multipart/form-data;boundary=" + boundary; private byte[] multipartBody; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_multipart); byte[] fileData1 = getFileDataFromDrawable(context, R.drawable.ic_action_android); byte[] fileData2 = getFileDataFromDrawable(context, R.drawable.ic_action_book); ByteArrayOutputStream bos = new ByteArrayOutputStream(); DataOutputStream dos = new DataOutputStream(bos); try { // the first file buildPart(dos, fileData1, "ic_action_android.png"); // the second file buildPart(dos, fileData2, "ic_action_book.png"); // send multipart form data necesssary after file data dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd); // pass to multipart body multipartBody = bos.toByteArray(); } catch (IOException e) { e.printStackTrace(); } String url = "http://192.168.1.100/api/postfile"; MultipartRequest multipartRequest = new MultipartRequest(url, null, mimeType, multipartBody, new Response.Listener<NetworkResponse>() { @Override public void onResponse(NetworkResponse response) { Toast.makeText(context, "Upload successfully!", Toast.LENGTH_SHORT).show(); } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { Toast.makeText(context, "Upload failed!\r\n" + error.toString(), Toast.LENGTH_SHORT).show(); } }); VolleySingleton.getInstance(context).addToRequestQueue(multipartRequest); } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.menu_multipart, menu); return true; } @Override public boolean onOptionsItemSelected(MenuItem item) { // Handle action bar item clicks here. The action bar will // automatically handle clicks on the Home/Up button, so long // as you specify a parent activity in AndroidManifest.xml. int id = item.getItemId(); //noinspection SimplifiableIfStatement if (id == R.id.action_settings) { return true; } return super.onOptionsItemSelected(item); } private void buildPart(DataOutputStream dataOutputStream, byte[] fileData, String fileName) throws IOException { dataOutputStream.writeBytes(twoHyphens + boundary + lineEnd); dataOutputStream.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\"; filename=\"" + fileName + "\"" + lineEnd); dataOutputStream.writeBytes(lineEnd); ByteArrayInputStream fileInputStream = new ByteArrayInputStream(fileData); int bytesAvailable = fileInputStream.available(); int maxBufferSize = 1024 * 1024; int bufferSize = Math.min(bytesAvailable, maxBufferSize); byte[] buffer = new byte[bufferSize]; // read file and write it into form... int bytesRead = fileInputStream.read(buffer, 0, bufferSize); while (bytesRead > 0) { dataOutputStream.write(buffer, 0, bufferSize); bytesAvailable = fileInputStream.available(); bufferSize = Math.min(bytesAvailable, maxBufferSize); bytesRead = fileInputStream.read(buffer, 0, bufferSize); } dataOutputStream.writeBytes(lineEnd); } private byte[] getFileDataFromDrawable(Context context, int id) { Drawable drawable = ContextCompat.getDrawable(context, id); Bitmap bitmap = ((BitmapDrawable) drawable).getBitmap(); ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); bitmap.compress(Bitmap.CompressFormat.PNG, 0, byteArrayOutputStream); return byteArrayOutputStream.toByteArray(); } } 

MultipartRequest.java:

 package com.example.multipartvolley; import com.android.volley.AuthFailureError; import com.android.volley.NetworkResponse; import com.android.volley.ParseError; import com.android.volley.Request; import com.android.volley.Response; import com.android.volley.VolleyError; import com.android.volley.toolbox.HttpHeaderParser; import java.util.Map; class MultipartRequest extends Request<NetworkResponse> { private final Response.Listener<NetworkResponse> mListener; private final Response.ErrorListener mErrorListener; private final Map<String, String> mHeaders; private final String mMimeType; private final byte[] mMultipartBody; public MultipartRequest(String url, Map<String, String> headers, String mimeType, byte[] multipartBody, Response.Listener<NetworkResponse> listener, Response.ErrorListener errorListener) { super(Method.POST, url, errorListener); this.mListener = listener; this.mErrorListener = errorListener; this.mHeaders = headers; this.mMimeType = mimeType; this.mMultipartBody = multipartBody; } @Override public Map<String, String> getHeaders() throws AuthFailureError { return (mHeaders != null) ? mHeaders : super.getHeaders(); } @Override public String getBodyContentType() { return mMimeType; } @Override public byte[] getBody() throws AuthFailureError { return mMultipartBody; } @Override protected Response<NetworkResponse> parseNetworkResponse(NetworkResponse response) { try { return Response.success( response, HttpHeaderParser.parseCacheHeaders(response)); } catch (Exception e) { return Response.error(new ParseError(e)); } } @Override protected void deliverResponse(NetworkResponse response) { mListener.onResponse(response); } @Override public void deliverError(VolleyError error) { mErrorListener.onErrorResponse(error); } } 

अद्यतन करें:

पाठ भाग के लिए, कृपया @ RacZo के उत्तर नीचे देखें।

Solutions Collecting From Web of "वॉली के साथ और एचटीपीटीटीटी के बिना काम करने वाले डाक बहुपयोगी अनुरोध"

मैं अपना कोड @RacZo और @ BNK को फिर से लिखना और अधिक मॉड्यूलर और उपयोग करने में आसान है

 VolleyMultipartRequest multipartRequest = new VolleyMultipartRequest(Request.Method.POST, url, new Response.Listener<NetworkResponse>() { @Override public void onResponse(NetworkResponse response) { String resultResponse = new String(response.data); // parse success output } }, new Response.ErrorListener() { @Override public void onErrorResponse(VolleyError error) { error.printStackTrace(); } }) { @Override protected Map<String, String> getParams() { Map<String, String> params = new HashMap<>(); params.put("api_token", "gh659gjhvdyudo973823tt9gvjf7i6ric75r76"); params.put("name", "Angga"); params.put("location", "Indonesia"); params.put("about", "UI/UX Designer"); params.put("contact", "angga@email.com"); return params; } @Override protected Map<String, DataPart> getByteData() { Map<String, DataPart> params = new HashMap<>(); // file name could found file base or direct access from real path // for now just get bitmap data from ImageView params.put("avatar", new DataPart("file_avatar.jpg", AppHelper.getFileDataFromDrawable(getBaseContext(), mAvatarImage.getDrawable()), "image/jpeg")); params.put("cover", new DataPart("file_cover.jpg", AppHelper.getFileDataFromDrawable(getBaseContext(), mCoverImage.getDrawable()), "image/jpeg")); return params; } }; VolleySingleton.getInstance(getBaseContext()).addToRequestQueue(multipartRequest); 

मेरे सार में कोड VolleyMultipartRequest से भरा चेक करें

अच्छा जवाब @ बीएनके!

बस जवाब में जोड़ना चाहते हैं … मैं यह जानने की कोशिश कर रहा था कि कैसे पाठ फ़ील्ड को शरीर में जोड़ना है और ऐसा करने के लिए निम्नलिखित फ़ंक्शन बनाया है:

 private void buildTextPart(DataOutputStream dataOutputStream, String parameterName, String parameterValue) throws IOException { dataOutputStream.writeBytes(twoHyphens + boundary + lineEnd); dataOutputStream.writeBytes("Content-Disposition: form-data; name=\"" + parameterName + "\"" + lineEnd); dataOutputStream.writeBytes("Content-Type: text/plain; charset=UTF-8" + lineEnd); dataOutputStream.writeBytes(lineEnd); dataOutputStream.writeBytes(parameterValue + lineEnd); } 

यह बहुत अच्छी तरह से काम कर रहा है, इसलिए मुझे आशा है कि यह मदद करता है।

उन लोगों के लिए जो मेरे जैसे यूटीएफ -8 पैरामीटर भेजने के लिए संघर्ष कर रहे हैं और अभी भी कोई भाग्य नहीं है … जो समस्या थी वह डेटाऑप्टस्ट्रस्ट में थी, और @RacZo का कोड नीचे कोड में बदल गया था

 private void buildTextPart(DataOutputStream dataOutputStream, String parameterName, String parameterValue) throws IOException { dataOutputStream.writeBytes(twoHyphens + boundary + lineEnd); dataOutputStream.writeBytes("Content-Disposition: form-data; name=\""); dataOutputStream.write(parameterName.getBytes("UTF-8")); dataOutputStream.writeBytes(lineEnd); dataOutputStream.writeBytes("Content-Type: text/plain; charset=UTF-8" + lineEnd); dataOutputStream.writeBytes(lineEnd); dataOutputStream.write(parameterValue.getBytes("UTF-8")); dataOutputStream.writeBytes(lineEnd); } 

मेरे जैसे किसी के लिए यह काम आशा करो