我正在尝试将我的Android连接到我的as400服务器。不幸的是,当我点击My Connexion按钮时,驱动程序未加载,我不知道为什么。
这是我的代码:
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 :(得分:1)
我个人没有尝试过,但IBM Toolbox for Java(jt400.jar)可能与Dalvik JVM不兼容。 Dalvik不是Java VM的100%兼容实现。
您确定要在移动设备上分发像Toolbox这样的库的重量和安全性吗?我建议服务器(AS / 400)应用程序为移动客户端提供服务,同时管理安全性,缓存等。
像Grails这样可以在AS / 400上本地部署的框架使服务器应用程序变得轻而易举。通过HTTP处理XML或JSON服务将使移动应用程序更容易,更强大,并且更容易维护。
我在生产中有类似的应用程序,支持超过一百个Windows CE / Mobile客户端(Motorola / Symbol手持设备)。我希望在硬件可用后将客户端移植到Android。