Java android将图像上传到服务器

Java android将图像上传到服务器,java,android,android-image,Java,Android,Android Image,我正在尝试将手机摄像头拍摄的图像上传到服务器。因为我刚开始在android上上传图片,所以对此我不太了解。谷歌搜索后,我在互联网上学习了一个教程,它确实可以作为一个单独的应用程序使用,但当我在应用程序中使用同一个类时,它就不再起作用了。我的日志中有错误(我将在本文末尾发布)。我不知道这个错误是什么意思,我如何才能解决这个问题。请帮助我,我怎样才能使这项工作 这是我的相机活动代码 public class Camera extends Activity { ImageView ivUserImag

我正在尝试将手机摄像头拍摄的图像上传到服务器。因为我刚开始在android上上传图片,所以对此我不太了解。谷歌搜索后,我在互联网上学习了一个教程,它确实可以作为一个单独的应用程序使用,但当我在应用程序中使用同一个类时,它就不再起作用了。我的日志中有错误(我将在本文末尾发布)。我不知道这个错误是什么意思,我如何才能解决这个问题。请帮助我,我怎样才能使这项工作

这是我的相机活动代码

public class Camera extends Activity {
ImageView ivUserImage;
Button bUpload;
Intent i;
int CameraResult = 0;
Bitmap bmp;
FileUpload fu;
@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.camera);

    ivUserImage = (ImageView)findViewById(R.id.ivUserImage);
    bUpload = (Button)findViewById(R.id.bUpload);
    openCamera();
}

private void openCamera() {
    i = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
    startActivityForResult(i, CameraResult);
}

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {

    super.onActivityResult(requestCode, resultCode, data);
    if(resultCode == RESULT_OK) {
        Bundle extras = data.getExtras();
        //Log.e("Image: ", data.toString());
        bmp = (Bitmap) extras.get("data");
        ivUserImage.setImageBitmap(bmp);

        bUpload.setOnClickListener(new View.OnClickListener() {

            public void onClick(View v) {
                // TODO Auto-generated method stub
                //Toast.makeText(getApplicationContext(), bmp.toString(), Toast.LENGTH_SHORT).show();
                fu = new FileUpload(bmp.toString());
            }
        });
    }
}

}
这是我的文件上传类

public class FileUpload extends Activity {
TextView tv;
Button b;
int serverResponseCode = 0;
ProgressDialog dialog = null;

public FileUpload(final String bmp) {
    dialog = ProgressDialog.show(FileUpload.this, "", "Uploading file...", true);
    new Thread(new Runnable() {
           public void run() {
                runOnUiThread(new Runnable() {
                       public void run() {
                           tv.setText("uploading started.....");
                       }
                   });
            int response= uploadFile(bmp);
            //Log.e("Response: ", response);
            System.out.println("RES : " + response);
           }
         }).start();
}

public int uploadFile(String sourceFileUri) {
    String upLoadServerUri = "http://www.example.info/androidfileupload/index.php";
    String fileName = sourceFileUri;

    HttpURLConnection conn = null;
    DataOutputStream dos = null;
    String lineEnd = "\r\n";
    String twoHyphens = "--";
    String boundary = "*****";
    int bytesRead, bytesAvailable, bufferSize;
    byte[] buffer;
    int maxBufferSize = 1 * 1024 * 1024;
    File sourceFile = new File(sourceFileUri);
    if (!sourceFile.isFile()) {
     Log.e("uploadFile", "Source File Does not exist");
     return 0;
    }

    try { // open a URL connection to the Servlet
     FileInputStream fileInputStream = new FileInputStream(sourceFile);
     URL url = new URL(upLoadServerUri);
     conn = (HttpURLConnection) url.openConnection(); // Open a HTTP  connection to  the URL
     conn.setDoInput(true); // Allow Inputs
     conn.setDoOutput(true); // Allow Outputs
     conn.setUseCaches(false); // Don't use a Cached Copy
     conn.setRequestMethod("POST");
     conn.setRequestProperty("Connection", "Keep-Alive");
     conn.setRequestProperty("ENCTYPE", "multipart/form-data");
     conn.setRequestProperty("Content-Type", "multipart/form-data;boundary=" + boundary);
     conn.setRequestProperty("uploaded_file", fileName);
     dos = new DataOutputStream(conn.getOutputStream());

     dos.writeBytes(twoHyphens + boundary + lineEnd);
     dos.writeBytes("Content-Disposition: form-data; name=\"uploaded_file\";filename=\""+ fileName + "\"" + lineEnd);
     dos.writeBytes(lineEnd);

     bytesAvailable = fileInputStream.available(); // create a buffer of  maximum size

     bufferSize = Math.min(bytesAvailable, maxBufferSize);
     buffer = new byte[bufferSize];

     // read file and write it into form...
     bytesRead = fileInputStream.read(buffer, 0, bufferSize);  

     while (bytesRead > 0) {
       dos.write(buffer, 0, bufferSize);
       bytesAvailable = fileInputStream.available();
       bufferSize = Math.min(bytesAvailable, maxBufferSize);
       bytesRead = fileInputStream.read(buffer, 0, bufferSize);
      }

     // send multipart form data necesssary after file data...
     dos.writeBytes(lineEnd);
     dos.writeBytes(twoHyphens + boundary + twoHyphens + lineEnd);

     // Responses from the server (code and message)
     serverResponseCode = conn.getResponseCode();
     String serverResponseMessage = conn.getResponseMessage();

     Log.i("uploadFile", "HTTP Response is : " + serverResponseMessage + ": " + serverResponseCode);
     if(serverResponseCode == 200){
         runOnUiThread(new Runnable() {
              public void run() {
                  tv.setText("File Upload Completed.");
                  Toast.makeText(FileUpload.this, "File Upload Complete.", Toast.LENGTH_SHORT).show();
                  }
              });
         }    

         //close the streams //
         fileInputStream.close();
         dos.flush();
         dos.close();

    } catch (MalformedURLException ex) {
        dialog.dismiss();
        ex.printStackTrace();
        Toast.makeText(FileUpload.this, "MalformedURLException", Toast.LENGTH_SHORT).show();
    Log.e("Upload file to server", "error: " + ex.getMessage(), ex);
} catch (Exception e) {
    dialog.dismiss();
    e.printStackTrace();
    Toast.makeText(FileUpload.this, "Exception : " + e.getMessage(), Toast.LENGTH_SHORT).show();
    Log.e("Upload file to server Exception", "Exception : " + e.getMessage(), e);
}
dialog.dismiss();
return serverResponseCode;
} }

这是我在日志中得到的信息

06-10 14:26:55.320: W/IInputConnectionWrapper(23770): showStatusIcon on inactive InputConnection
06-10 14:27:03.765: D/AndroidRuntime(23770): Shutting down VM
06-10 14:27:03.765: W/dalvikvm(23770): threadid=1: thread exiting with uncaught exception (group=0x4001e578)
06-10 14:27:03.775: E/AndroidRuntime(23770): FATAL EXCEPTION: main
06-10 14:27:03.775: E/AndroidRuntime(23770): java.lang.IllegalStateException: System services not available to Activities before onCreate()
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.Activity.getSystemService(Activity.java:3562)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.Dialog.<init>(Dialog.java:141)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.AlertDialog.<init>(AlertDialog.java:63)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.ProgressDialog.<init>(ProgressDialog.java:80)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.ProgressDialog.<init>(ProgressDialog.java:76)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.ProgressDialog.show(ProgressDialog.java:101)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.ProgressDialog.show(ProgressDialog.java:90)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at com.zafar.login.FileUpload.<init>(FileUpload.java:25)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at com.zafar.login.Camera$1.onClick(Camera.java:52)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.view.View.performClick(View.java:2538)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.view.View$PerformClick.run(View.java:9152)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.os.Handler.handleCallback(Handler.java:587)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.os.Handler.dispatchMessage(Handler.java:92)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.os.Looper.loop(Looper.java:130)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at android.app.ActivityThread.main(ActivityThread.java:3691)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at java.lang.reflect.Method.invokeNative(Native Method)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at java.lang.reflect.Method.invoke(Method.java:507)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
06-10 14:27:03.775: E/AndroidRuntime(23770):    at dalvik.system.NativeStart.main(Native Method)
06-10 14:26:55.320:W/IInputConnectionWrapper(23770):在非活动InputConnection上显示状态图标
06-10 14:27:03.765:D/AndroidRuntime(23770):关闭虚拟机
06-10 14:27:03.765:W/dalvikvm(23770):threadid=1:线程以未捕获异常退出(组=0x4001e578)
06-1014:27:03.775:E/AndroidRuntime(23770):致命异常:主
06-10 14:27:03.775:E/AndroidRuntime(23770):java.lang.IllegalStateException:onCreate()之前的活动无法使用系统服务
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.app.Activity.getSystemService(Activity.java:3562)上
06-1014:27:03.775:E/AndroidRuntime(23770):在android.app.Dialog(Dialog.java:141)上
06-1014:27:03.775:E/AndroidRuntime(23770):在android.app.AlertDialog.(AlertDialog.java:63)
06-1014:27:03.775:E/AndroidRuntime(23770):在android.app.ProgressDialog.(ProgressDialog.java:80)
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.app.ProgressDialog(ProgressDialog.java:76)上
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.app.ProgressDialog.show(ProgressDialog.java:101)上
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.app.ProgressDialog.show(ProgressDialog.java:90)上
06-1014:27:03.775:E/AndroidRuntime(23770):在com.zafar.login.FileUpload.(FileUpload.java:25)
06-1014:27:03.775:E/AndroidRuntime(23770):在com.zafar.login.Camera$1.onClick(Camera.java:52)
06-1014:27:03.775:E/AndroidRuntime(23770):在android.view.view.performClick(view.java:2538)
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.view.view$PerformClick.run(view.java:9152)
06-1014:27:03.775:E/AndroidRuntime(23770):在android.os.Handler.handleCallback(Handler.java:587)上
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.os.Handler.dispatchMessage(Handler.java:92)上
06-1014:27:03.775:E/AndroidRuntime(23770):在android.os.Looper.loop(Looper.java:130)上
06-10 14:27:03.775:E/AndroidRuntime(23770):在android.app.ActivityThread.main(ActivityThread.java:3691)上
06-10 14:27:03.775:E/AndroidRuntime(23770):位于java.lang.reflect.Method.Invokenactive(本机方法)
06-1014:27:03.775:E/AndroidRuntime(23770):在java.lang.reflect.Method.invoke(Method.java:507)
06-10 14:27:03.775:E/AndroidRuntime(23770):在com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)
06-1014:27:03.775:E/AndroidRuntime(23770):在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
06-10 14:27:03.775:E/AndroidRuntime(23770):在dalvik.system.NativeStart.main(本机方法)

您可以使用
新建
创建
对象文件上传
活动。在Android中,建议将活动设计为独立的模块,活动由Android创建。如果您想与其他活动进行沟通,您应该使用Intent来进行沟通

fu = new FileUpload(bmp.toString()); // here make error.

在android中,无法创建其他活动的对象

使用
new
创建
对象文件上传
活动。在Android中,建议将活动设计为独立的模块,活动由Android创建。如果您想与其他活动进行沟通,您应该使用Intent来进行沟通

fu = new FileUpload(bmp.toString()); // here make error.

在android中,无法创建其他活动的对象

我建议您创建一个FTP服务器,并使用FTP上传文件。以下代码是从FTP服务器获取文件的方法。自定义以上载:

public static boolean getFile(String serverName, String userName,
        String password, String serverFilePath, String localFilePath)
        throws Exception {

    FTPClient ftp = new FTPClient();

    try {
        // ftp.setCopyStreamListener();

        ftp.connect(serverName);
        int reply = ftp.getReplyCode();

        if (!FTPReply.isPositiveCompletion(reply)) {
            ftp.disconnect();
            return false;
        }
    } catch (IOException e) {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException f) {
                throw e;
            }
        }
        throw e;
    } catch (Exception e) {
        throw e;
    }

    try {
        // String filePath = "system/mswin.98/SETUP0.WAV";
        if (!ftp.login(userName, password)) {
            ftp.logout();
        }
        // if (binaryTransfer)
        ftp.setFileType(FTPClient.BINARY_FILE_TYPE);
        // ftp.enterLocalPassiveMode();
        ftp.enterLocalActiveMode();

        OutputStream output;

        if (checkAndCreateDirectories(localFilePath)) {
            output = new FileOutputStream(localFilePath);
            ftp.retrieveFile(serverFilePath, output);
            output.close();
        }

        ftp.noop(); // check that control connection is working OK
        ftp.logout();
        return true;

    } catch (FTPConnectionClosedException e) {
        throw e;
    } catch (IOException e) {
        throw e;
    } catch (Exception e) {
        throw e;
    } finally {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException f) {
                throw f;
            }
        }

    }

}

我建议您创建一个FTP服务器,并使用FTP上传文件。以下代码是从FTP服务器获取文件的方法。自定义以上载:

public static boolean getFile(String serverName, String userName,
        String password, String serverFilePath, String localFilePath)
        throws Exception {

    FTPClient ftp = new FTPClient();

    try {
        // ftp.setCopyStreamListener();

        ftp.connect(serverName);
        int reply = ftp.getReplyCode();

        if (!FTPReply.isPositiveCompletion(reply)) {
            ftp.disconnect();
            return false;
        }
    } catch (IOException e) {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException f) {
                throw e;
            }
        }
        throw e;
    } catch (Exception e) {
        throw e;
    }

    try {
        // String filePath = "system/mswin.98/SETUP0.WAV";
        if (!ftp.login(userName, password)) {
            ftp.logout();
        }
        // if (binaryTransfer)
        ftp.setFileType(FTPClient.BINARY_FILE_TYPE);
        // ftp.enterLocalPassiveMode();
        ftp.enterLocalActiveMode();

        OutputStream output;

        if (checkAndCreateDirectories(localFilePath)) {
            output = new FileOutputStream(localFilePath);
            ftp.retrieveFile(serverFilePath, output);
            output.close();
        }

        ftp.noop(); // check that control connection is working OK
        ftp.logout();
        return true;

    } catch (FTPConnectionClosedException e) {
        throw e;
    } catch (IOException e) {
        throw e;
    } catch (Exception e) {
        throw e;
    } finally {
        if (ftp.isConnected()) {
            try {
                ftp.disconnect();
            } catch (IOException f) {
                throw f;
            }
        }

    }

}

您是否在Android Mainifest中设置了所有必需的权限?我想它需要“”internet权限,我已将您的主要活动的上下文传递给此上载类。您是否在Android Mainifest中设置了所有必需的权限?我想它需要“”internet权限,我已将您的主要活动的上下文传递给了您到这个上传类。是的,我不希望这个类成为一个活动。我想创建一个全新的类,即类FileUpload{}。但是当我改变它时,它显示了大量的错误。我的意思是有太多的红色下划线。public FileUpload(上下文上下文,最终字符串bmp){dialog=ProgressDialog.show(上下文,“,”upload file…”,true);new Thread(new Runnable(){public void run(){runnuithread(new Runnable(){public void run(){tv.setText(“上载已开始…”;}}});int-response=uploadFile(bmp);//Log.e(“response:”,response);System.out.println(“RES:”+response);}}).start();}和fu=newfileupload(this,bmp.toString());我没有收到你的评论。这是什么意思?你能详细说明一下吗?是的,我不想让这个类成为一个活动。我想创建一个全新的类,即类FileUpload{}。但是当我更改它时,它显示了大量错误。我的意思是有太多红色下划线的行。public FileUpload(上下文上下文,最终字符串bmp){dialog=ProgressDialog.show(上下文,“,”上载文件…”,true);新线程(新Runnable(){public void run(){runnuithread(新Runnable(){public void run())