2012-06-05 53 views
1

我試圖讓我的Android連接到我的as400服務器。不幸的是,當我點擊My Connexion按鈕時,驅動程序未加載,我不知道爲什麼。Android應用程序連接到as400數據庫

這裏我是代碼:

package hello.world; 

import java.sql.Connection; 
import java.sql.DriverManager; 
import java.sql.SQLException; 

import android.app.Activity; 
import android.os.Bundle; 
import android.view.View; 


public class HelloworldActivity extends Activity { 
    /** Called when the activity is first created. */ 


    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.main); 
    } 


    public void Connexion(View view) throws SQLException { 
     System.out.println("Tentative de connexion à la base de donnée."); //Connexion 
     String driver = "com.ibm.as400.access.AS400JDBCDriver"; 

     String url = "jdbc:as400://BEAUFIX;transaction isolation=read uncommitted;date format=iso;naming=system;libraries=*LIBL"; 
     Connection conn = null; 
     String userName = "GMAOBD60"; 
     String password = "GMAOBD60"; 

     try { 
      Class.forName(driver).newInstance(); 
      conn = DriverManager.getConnection(url,userName,password); 
      System.out.println("Connected to the database"); 
      conn.close(); 
      System.out.println("Disconnected from database"); 
     } catch (Exception e) { 
      e.printStackTrace(); 
      System.out.println("ERROR"); 

} 
} 
} 

這裏是我的XMD代碼:

<Button android:id="@+id/Connexion" android:layout_width="196dp" android:layout_height="wrap_content" android:layout_marginLeft="50dp" android:layout_marginTop="100dp" android:text="@string/Connexion" android:layerType="hardware" android:onClick="Connexion" />

這裏是我的錯誤日誌:

06-05 07:18:56.100: W/System.err(564): java.lang.ClassNotFoundException: com.ibm.as400.access.AS400JDBCDriver 
06-05 07:18:56.155: W/System.err(564): at java.lang.Class.classForName(Native Method) 
06-05 07:18:56.180: W/System.err(564): at java.lang.Class.forName(Class.java:217) 
06-05 07:18:56.212: W/System.err(564): at java.lang.Class.forName(Class.java:172) 
06-05 07:18:56.241: W/System.err(564): at hello.world.HelloworldActivity.Connexion(HelloworldActivity.java:33) 
06-05 07:18:56.271: W/System.err(564): at java.lang.reflect.Method.invokeNative(Native Method) 
06-05 07:18:56.290: W/System.err(564): at java.lang.reflect.Method.invoke(Method.java:511) 
06-05 07:18:56.321: W/System.err(564): at android.view.View$1.onClick(View.java:3039) 
06-05 07:18:56.340: W/System.err(564): at android.view.View.performClick(View.java:3511) 
06-05 07:18:56.371: W/System.err(564): at android.view.View$PerformClick.run(View.java:14105) 
06-05 07:18:56.371: W/System.err(564): at android.os.Handler.handleCallback(Handler.java:605) 
06-05 07:18:56.380: W/System.err(564): at android.os.Handler.dispatchMessage(Handler.java:92) 
06-05 07:18:56.391: W/System.err(564): at android.os.Looper.loop(Looper.java:137) 
06-05 07:18:56.391: W/System.err(564): at android.app.ActivityThread.main(ActivityThread.java:4424) 
06-05 07:18:56.401: W/System.err(564): at java.lang.reflect.Method.invokeNative(Native Method) 
06-05 07:18:56.410: W/System.err(564): at java.lang.reflect.Method.invoke(Method.java:511) 
06-05 07:18:56.421: W/System.err(564): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
06-05 07:18:56.431: W/System.err(564): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
06-05 07:18:56.431: W/System.err(564): at dalvik.system.NativeStart.main(Native Method) 
06-05 07:18:56.441: W/System.err(564): Caused by: java.lang.NoClassDefFoundError: com/ibm/as400/access/AS400JDBCDriver 
06-05 07:18:56.460: W/System.err(564): ... 18 more 
06-05 07:18:56.460: W/System.err(564): Caused by: java.lang.ClassNotFoundException: com.ibm.as400.access.AS400JDBCDriver 
06-05 07:18:56.481: W/System.err(564): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61) 
06-05 07:18:56.492: W/System.err(564): at java.lang.ClassLoader.loadClass(ClassLoader.java:501) 
06-05 07:18:56.492: W/System.err(564): at java.lang.ClassLoader.loadClass(ClassLoader.java:461) 
06-05 07:18:56.500: W/System.err(564): ... 18 more 

而且我已經試過很多事情,但我總是遇到一個錯誤。幫助我,請我想這個工作:(

而且沒有我沒有忘記匯入我的jt400.jar這是「com.ibm.as400.access.AS400JDBCDriver」

謝謝你在前進, 奧勒利安

+0

我即將嘗試此操作。根據我的理解,您不需要DB2 Connect許可即可使用此許可,但如果您想在桌面客戶端中使用.NET提供程序,則需要使用此許可。 我能夠在Android上使用JDBC成功連接到SQL Server,Oracle和MySQL。 – Monstieur

回答

1

我個人還沒有嘗試過,但IBM Toolbox for Java的(存在jt400.jar)可能無法與在Dalvik JVM兼容。Dalvik的是不是100%兼容實現的Java虛擬機。

你確定你想要像移動設備上分發的工具箱這樣的庫的重量和安全含義嗎?我會推薦爲erver(AS/400)應用程序在管理安全性,緩存等時向移動客戶端提供服務。

可以在AS/400上本地部署的框架如Grails使服務器應用程序變得輕而易舉。通過HTTP處理XML或JSON服務將使移動應用程序變得更容易,更強大,並且更容易維護。

我有一個類似的應用程序支持超過一百個Windows CE /移動客戶端(Motorola/Symbol掌上電腦)。一旦硬件可用,我期待將客戶端移植到Android。

相關問題