如何将活动类中的值传递给android中的java类?

时间:2015-01-13 18:16:48

标签: java android mysql

我编写了一个程序,其中我通过共享偏好设置了一些值,并通过共享偏好和一个来自意图,并且值完全显示我通过Toast测试它 现在我想将这些值存储在mysql数据库中,因为我已经编写了一个普通的java类,它有jdbc预处理语句,但是我无法弄清楚如何将一个值从我的activity类传递给普通的java类

在下面发布我的代码,请告诉我我需要做什么

public class Service_Access extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.service_access);

    // Get Email ID from Shared preferences
    // SharedPreferences prefs = getSharedPreferences("UserDetails",
    // Context.MODE_PRIVATE);
    // String eMailId = prefs.getString("eMailId", "");

    // Get Email ID from Shared preferences
    SharedPreferences prefs = getSharedPreferences("UserDetails", Context.MODE_PRIVATE);
    String eMailId = prefs.getString("eMailId", "");
    String registrationId = prefs.getString("regId", "");
    // Intent Message sent from Broadcast Receiver
    String str = getIntent().getStringExtra("msg");

    if (str != null) {
        // Set the message
        lblMessage = (TextView) findViewById(R.id.txtView);
        lblMessage.setText(str + "\n");
        // Toast.makeText(getBaseContext(), registrationId + "\n" + eMailId
        // + "\n", Toast.LENGTH_LONG).show();
        ServiceSql sersql = new ServiceSql();
        sersql.insertValues(eMailId, registrationId, str);
    }

}

}

在上面的类中,我获得的值存储在String str,emailid,registrationid中 我想在下面的类中设置这些值,prep.setString(1,“”)等等

ServiceSql.java

public class ServiceSql {
Connection connection = null;
PreparedStatement prep = null;
ResultSet rSet = null;
Statement state = null;
java.sql.Timestamp timestamp = getCurrentJavaSqlTimestamp();
Context context;

public static java.sql.Timestamp getCurrentJavaSqlTimestamp() {
    java.util.Date date = new java.util.Date();
    return new java.sql.Timestamp(date.getTime());
}

public void readDatabase() {
    try {

        Class.forName("com.mysql.jdbc.Driver");
        connection = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/gcm",
        "root", "root");
        state = (Statement) connection.createStatement();

        prep = (PreparedStatement) connection
                .prepareStatement("Select email,gcm_regid,created_at,gcm_message from  
        gcm.gcm_users");
        rSet = prep.executeQuery();

    } catch (Exception e) {
        // TODO: handle exception
        e.printStackTrace();
    }
}

public void insertValues(String email, String regID, String msg) {
    try {
        Class.forName("com.mysql.jdbc.Driver");
        connection = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/gcm",
        "root", "root");
        state = (Statement) connection.createStatement();

        prep = (PreparedStatement) connection
                .prepareStatement("insert into 
        gcm.gcm_users(email,gcm_regid,created_at,gcm_message)"
                        + "values(?,?,?,?)");

        prep.setString(1, email);
        prep.setString(2, regID);
        prep.setTimestamp(3, timestamp);
        prep.setString(4, msg);
        prep.executeUpdate();
    } catch (Exception e) {
        // TODO: handle exception
        e.printStackTrace();
    }
}

}

请需要一些帮助 感谢你

1 个答案:

答案 0 :(得分:0)

读取另一个类中的sharedPreference值,并在数据库中写入这些值。

SharedPreferences s = SharedMyAPP.getAppContext()。getSharedPreferences(“myPreferences”,Context.MODE_PRIVATE); value = s.getString(key,“”);