Android 는 Volley 를 사용 하여 파일 업로드 기능 을 실현 합 니 다.
/**
* Created by wangshihui on 2015/11/30.
*
* url:.....
method:post
:file
:file key, mFilePartName;
, ,
*/
public class MultipartRequest extends Request<JSONObject> {
private String mHeader;
private Map<String, String> mMap;
private String cookieFromResp = "";
private Map<String, String> headerMap = new HashMap<>();
private MultipartEntity entity = new MultipartEntity();
private final Response.Listener<JSONObject> mListener;
private final File mFilePart;
private String mFilePartName;
/**
* @param url
* @param listener
* @param errorListener
* @param file_name
* @param file
*/
public MultipartRequest(String url, Response.Listener<JSONObject> listener, Response.ErrorListener errorListener, String file_name,File file)
{
super(Method.POST, url, errorListener);
mListener = listener;
mFilePart = file;
mFilePartName=file_name;
buildMultipartEntity();
}
/**
*
*/
private void buildMultipartEntity()
{
entity.addPart(mFilePartName, new FileBody(mFilePart));
}
@Override
public String getBodyContentType()
{
return entity.getContentType().getValue();
}
@Override
public byte[] getBody() throws AuthFailureError
{
ByteArrayOutputStream bos = new ByteArrayOutputStream();
try
{
entity.writeTo(bos);
}
catch (IOException e)
{
VolleyLog.e("IOException writing to ByteArrayOutputStream");
}
return bos.toByteArray();
}
/**
* @param response
* @return
*/
@Override
protected Response<JSONObject> parseNetworkResponse(NetworkResponse response)
{
try {
JSONObject jsonObject;
System.out.println(response.headers.toString());
if (response.data.length != 0) {
String jsonString = new String(response.data, HttpHeaderParser.parseCharset(response.headers));
jsonObject = new JSONObject(jsonString);
} else {
jsonObject = new JSONObject();
}
//
mHeader = response.headers.toString();
// Cookie(JSESSIONID)
Pattern pattern = Pattern.compile("Set-Cookie=.*?;");
Matcher matcher = pattern.matcher(mHeader);
if (matcher.find()) {
cookieFromResp = matcher.group();
cookieFromResp = cookieFromResp.substring(11, cookieFromResp.length() - 1);
System.out.println("Cookie: " + cookieFromResp);
}
jsonObject.put("Cookie", cookieFromResp);
return Response.success(jsonObject,
HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
return Response.error(new ParseError(e));
} catch (JSONException je) {
return Response.error(new ParseError(je));
}
}
/**
* @param response
*/
@Override
protected void deliverResponse(JSONObject response)
{
mListener.onResponse(response);
}
@Override
protected Map<String, String> getParams() throws AuthFailureError {
return mMap;
}
/**
* @return
* @throws AuthFailureError
*/
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
return headerMap;
}
/**
* @return
*/
@Override
public RetryPolicy getRetryPolicy() {
RetryPolicy retryPolicy = new DefaultRetryPolicy(5000, DefaultRetryPolicy.DEFAULT_MAX_RETRIES, DefaultRetryPolicy.DEFAULT_BACKOFF_MULT);
return retryPolicy;
}
/**
* @param cookie
*/
// Cookie
public void setSendCookie(String cookie) {
headerMap.put("Cookie", cookie);
}
}
호출 방법 은 다음 과 같 습 니 다.
// url
String url = "http://182.92.....";
MultipartRequest multipartRequest = new MultipartRequest(
url, new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
saveSessionID(response);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError e) {
Log.e(TAG, e.getMessage(), e);
try {
byte[] htmlBodyBytes = e.networkResponse.data;
Log.e(TAG, new String(htmlBodyBytes), e);
} catch (Exception e1) {
e1.printStackTrace();
}
ToastUtil.showShortToast(UserCenterActivity.this, " ");
}
}, "file", mSelectedPictureFile);
multipartRequest.setSendCookie(loadSessionID());
multipartRequest.setTag(TAG);
client.addTask(multipartRequest);
private File mSelectedPictureFile;mSelected PictureFile 은 File 파일 이 고 매개 변수 이름 은 file 입 니 다.
통신 쿠키 저장 성공
saveSessionID(response);
전송 요청 쿠키 업로드
multipartRequest.setSendCookie(loadSessionID());
client 는 Volley 의 간단 한 패키지 입 니 다.
protected AsynHttpClient client;
public class AsynHttpClient {
//volley
private RequestQueue requestQueue;
//
private static AsynHttpClient instance;
private Context mContext;
private AsynHttpClient(Context context) {
requestQueue = Volley.newRequestQueue(context);
this.mContext = context;
}
/**
* , AsynHttpClient
* @param context
* @return
*/
public static AsynHttpClient getInstance(Context context) {
if (instance==null){
synchronized (AsynHttpClient.class){
if (instance==null){
instance=new AsynHttpClient(context);
}
}
}
return instance;
}
/**
* volley ,
* @param task
*/
public void addTask(Request task){
requestQueue.add(task);
}
public RequestQueue getRequestQueue() {
return requestQueue;
}
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Bitrise에서 배포 어플리케이션 설정 테스트하기이 글은 Bitrise 광고 달력의 23일째 글입니다. 자체 또는 당사 등에서 Bitrise 구축 서비스를 사용합니다. 그나저나 며칠 전 Bitrise User Group Meetup #3에서 아래 슬라이드를 발표했...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.