簡體   English   中英

Android FTP上傳錯誤

[英]Android FTP Upload Error

嗨,這是我的第一篇文章,對不起,如果我犯任何錯誤。

這是我的問題:我正在編寫一個應用程序,當您單擊一個按鈕時,該應用程序應該將今天的日期和時間保存在txt文件中,如果您單擊另一個按鈕,則將其發送到FTP服務器。 我將Apache Commons庫用於FTP連接。

那就是我的MainActivity:

package com.example.timestamp;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.DateFormat;
import java.util.Date;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import it.sauronsoftware.ftp4j.FTPClient;

public class MainActivity extends Activity {
    private static final String TAG = MainActivity.class.getName();
    final File log = new File("TimeStampLog.txt");
    final String SERVER = "***************";
    final String USERNAME = "**************";
    final String PASSWORD = "*************";
    final int PORT = 21;
    final TextView tv = (TextView) findViewById(R.id.textView1);
    Button save = (Button) findViewById(R.id.save);
    Button send = (Button) findViewById(R.id.send);

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        save.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                String date = DateFormat.getDateTimeInstance().format(new Date());
                tv.setText(date);
                StringBuilder sb = new StringBuilder();
                sb.append(date);
                sb.append("\r\n");
                sb.append(readFromFile());
                writeToFile(sb.toString());
            }
        });

        send.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                uploadFile(log);
            }
        });
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, 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();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    public void uploadFile(File fileName) {

        FTPClient client = new FTPClient();

        try {

            client.connect(SERVER, 21);
            client.login(USERNAME, PASSWORD);
            client.setType(FTPClient.TYPE_BINARY);

            client.upload(log);

        } catch (Exception e) {
            e.printStackTrace();
            try {
                client.disconnect(true);
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }

    }

    private void writeToFile(String data) {
        try {
            OutputStreamWriter outputStreamWriter = new OutputStreamWriter(
                    openFileOutput(log.getName(), Context.MODE_PRIVATE));
            outputStreamWriter.write(data);
            outputStreamWriter.flush();
            outputStreamWriter.close();
        } catch (IOException e) {
            Log.e(TAG, "File write failed: " + e.toString());
        }

    }

    private String readFromFile() {

        String ret = "";

        try {
            InputStream inputStream = openFileInput(log.getName());

            if (inputStream != null) {
                InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
                BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
                String receiveString = "";
                StringBuilder stringBuilder = new StringBuilder();

                while ((receiveString = bufferedReader.readLine()) != null) {
                    stringBuilder.append(receiveString);
                    stringBuilder.append("\r\n");
                }

                inputStream.close();
                ret = stringBuilder.toString();
            }
        } catch (FileNotFoundException e) {
            Log.e(TAG, "File not found: " + e.toString());
        } catch (IOException e) {
            Log.e(TAG, "Can not read file: " + e.toString());
        }

        return ret;
    }
}

我的XML文件:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.timestamp.MainActivity" >

<TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:ems="10" />

    <Button
        android:id="@+id/save"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/textView1"
        android:layout_below="@+id/textView1"
        android:layout_marginTop="60dp"
        android:text="@string/save" />

    <Button
        android:id="@+id/send"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/save"
        android:layout_alignBottom="@+id/save"
        android:layout_alignParentRight="true"
        android:text="@string/send" />

</RelativeLayout>

這是LogCat輸出:

08-14 13:51:45.919: E/AndroidRuntime(14598): FATAL EXCEPTION: main
08-14 13:51:45.919: E/AndroidRuntime(14598): Process: com.example.timestamp, PID: 14598
08-14 13:51:45.919: E/AndroidRuntime(14598): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.timestamp/com.example.timestamp.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'android.view.View android.view.Window.findViewById(int)' on a null object reference
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2209)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread.access$800(ActivityThread.java:144)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.os.Handler.dispatchMessage(Handler.java:102)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.os.Looper.loop(Looper.java:135)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread.main(ActivityThread.java:5221)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at java.lang.reflect.Method.invoke(Native Method)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at java.lang.reflect.Method.invoke(Method.java:372)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
08-14 13:51:45.919: E/AndroidRuntime(14598): Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'android.view.View android.view.Window.findViewById(int)' on a null object reference
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.Activity.findViewById(Activity.java:2071)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at com.example.timestamp.MainActivity.<init>(MainActivity.java:33)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at java.lang.reflect.Constructor.newInstance(Native Method)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at java.lang.Class.newInstance(Class.java:1572)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.Instrumentation.newActivity(Instrumentation.java:1065)
08-14 13:51:45.919: E/AndroidRuntime(14598):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2199)
08-14 13:51:45.919: E/AndroidRuntime(14598):    ... 10 more

是的,我將互聯網添加到了使用權限中

我認為問題可能是我需要另一個線程來實現FTP,並且我使用AsyncTask和Handler進行了嘗試,但我一直遇到相同的錯誤。

從LogCat輸出中,我可以看到您正在獲取NullPointerException,因為您已經初始化了Button和TextView,可以在其中聲明任何變量。

在調用setContentView(R.layout.activity_main);之前,您已經對所有Button和TextView進行了初始化和膨脹 OnCreate()方法中。 您已經在OnCreate方法中移動了代碼,然后嘗試上傳文件。

您可以嘗試以下代碼:

package com.example.timestamp;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.text.DateFormat;
import java.util.Date;

import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
import it.sauronsoftware.ftp4j.FTPClient;

public class MainActivity extends Activity {
    private static final String TAG = MainActivity.class.getName();
    final File log = new File("TimeStampLog.txt");
    final String SERVER = "***************";
    final String USERNAME = "**************";
    final String PASSWORD = "*************";
    final int PORT = 21;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        final TextView tv = (TextView) findViewById(R.id.textView1);
        Button save = (Button) findViewById(R.id.save);
        Button send = (Button) findViewById(R.id.send);
        save.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                String date = DateFormat.getDateTimeInstance().format(new Date());
                tv.setText(date);
                StringBuilder sb = new StringBuilder();
                sb.append(date);
                sb.append("\r\n");
                sb.append(readFromFile());
                writeToFile(sb.toString());
            }
        });

        send.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                uploadFile(log);
            }
        });
    }


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, 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();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }

    public void uploadFile(File fileName) {

        FTPClient client = new FTPClient();

        try {

            client.connect(SERVER, 21);
            client.login(USERNAME, PASSWORD);
            client.setType(FTPClient.TYPE_BINARY);

            client.upload(log);

        } catch (Exception e) {
            e.printStackTrace();
            try {
                client.disconnect(true);
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }

    }

    private void writeToFile(String data) {
        try {
            OutputStreamWriter outputStreamWriter = new OutputStreamWriter(
                    openFileOutput(log.getName(), Context.MODE_PRIVATE));
            outputStreamWriter.write(data);
            outputStreamWriter.flush();
            outputStreamWriter.close();
        } catch (IOException e) {
            Log.e(TAG, "File write failed: " + e.toString());
        }

    }

    private String readFromFile() {

        String ret = "";

        try {
            InputStream inputStream = openFileInput(log.getName());

            if (inputStream != null) {
                InputStreamReader inputStreamReader = new InputStreamReader(inputStream);
                BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
                String receiveString = "";
                StringBuilder stringBuilder = new StringBuilder();

                while ((receiveString = bufferedReader.readLine()) != null) {
                    stringBuilder.append(receiveString);
                    stringBuilder.append("\r\n");
                }

                inputStream.close();
                ret = stringBuilder.toString();
            }
        } catch (FileNotFoundException e) {
            Log.e(TAG, "File not found: " + e.toString());
        } catch (IOException e) {
            Log.e(TAG, "Can not read file: " + e.toString());
        }

        return ret;
    }
}

希望對您有所幫助!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM