安卓使用jdbc连接mysql_Android:使用JDBC连接MySql

我现在正在努力解决一个问题 . 我在免费托管服务器(fdb3.freehostingeu.com)中安装了一个数据库 . DB是MySql . 我从here导入了数据库连接的jar文件 . 我已将其作为gradle中的依赖项导入,我已在Manifest中设置了Internet权限以及所有内容 . 我正在使用AsyncTasc进行连接 .

这是带有方法的类 .

public class CheckLogin extends AsyncTask

{

String z = "";

Boolean isSuccess = false;

@Override

protected void onPreExecute()

{

// progressBar.setVisibility(View.VISIBLE);

}

@Override

protected void onPostExecute(String r)

{

// progressBar.setVisibility(View.GONE);

Toast.makeText(LoginActivity.this, r, Toast.LENGTH_SHORT).show();

if(isSuccess)

{

Toast.makeText(LoginActivity.this , "Login Successfull" , Toast.LENGTH_LONG).show();

//finish();

}

}

@Override

protected String doInBackground(String... params)

{

java.sql.Connection con;

String usernam = params[0];

String passwordd = params[1];

if(usernam.trim().equals("")|| passwordd.trim().equals(""))

z = "Please enter Username and Password";

else

{

try

{

con = connectionclass();

if (con == null)

{

z = "Check Your Internet Access!";

}

else

{

// Change below query according to your own database.

String query = "select * from owner where mail = '" + usernam.toString() + "' and password = '"+ passwordd.toString() +"' ";

Statement stmt = con.createStatement();

ResultSet rs = stmt.executeQuery(query);

if(rs.next())

{

z = "Login successful";

isSuccess=true;

con.close();

}

else

{

z = "Invalid Credentials!";

isSuccess = false;

}

}

}

catch (Exception ex)

{

isSuccess = false;

z = ex.getMessage();

}

}

return z;

}

}

@SuppressLint("NewApi")

public java.sql.Connection connectionclass()

{

StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();

StrictMode.setThreadPolicy(policy);

java.sql.Connection connection = null;

String ConnectionURL = null;

try

{

Class.forName("com.mysql.jdbc.Driver");

connection = DriverManager.getConnection(url, un, pas);

}

catch (SQLException se)

{

Log.e("error here 1 : ", se.getMessage());

}

catch (ClassNotFoundException e)

{

Log.e("error here 2 : ", e.getMessage());

}

catch (Exception e)

{

Log.e("error here 3 : ", e.getMessage());

}

return connection;

}

我把网址设置为

jdbc:mysql://185.176.43.41:3306/DB_name

站点说服务器IP的位置和端口是3306 . 以及用于连接数据库的用户名和密码 .

我不认为我使用了错误,但仍然在我调试我的应用程序时,我得到一个例外:

java.sql.SQLException:由于异常而无法连接到任何主机:java.net.SocketException:java.net.ConnectException:无法连接到/185.176.43.41(端口3306):连接失败:ECONNREFUSED(连接被拒绝) ** BEGIN NESTED EXCEPTION ** java.net.SocketException消息:java.net.ConnectException:无法连接到/185.176.43.41(端口3306):连接失败:ECONNREFUSED(连接被拒绝)STACKTRACE:java.net.SocketException:java .net.ConnectException:无法连接到/185.176.43.41(端口3306):连接失败:在com.mysql.jdbc的com.mysql.jdbc.StandardSocketFactory.connect(StandardSocketFactory.java:143)处出现ECONNREFUSED(连接被拒绝) . MysqlIO . (MysqlIO.java:225)位于com.mysql.jdbc.NonRegisteringDriver上的com.mysql.jdbc.Connection . (Connection.java:452)的com.mysql.jdbc.Connection.createNewIO(Connection.java:1805) . .connect(NonRegisteringDriver.java:411)位于java.sql.DriverManager.getConnection(DriverManager.java:179)的java.sql.DriverManager.getConnection( DriverManager.java:213)com.example.hotelreseration.LoginActivity.connectionclass(LoginActivity.java:234)at com.example.hotelreseration.LoginActivity $ CheckLogin.doInBackground(LoginActivity.java:184)at com.example.hotelreseration.LoginActivity $ checkLogin.doInBackground(LoginActivity.java:149)at android.os.AsyncTask $ 2.call(AsyncTask.java:307)at java.util.concurrent.FutureTask.run(FutureTask.java:237)at android.os.AsyncTask $ java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)上的$ SerialExecutor $ 1.run(AsyncTask.java:246)java.util.concurrent.ThreadPoolExecutor $ Worker.run(ThreadPoolExecutor.java:588) .lang.Thread.run(Thread.java:833) ** END NESTED EXCEPTION **

java.sql.Connection connection 为null,它不使用(url,un,pas)

我已经试图找到一种方式2天了,我已经尝试了一切 . 我不知道SQL数据库,我无法区分MySql和MSSql,并继续尝试与jtds连接到这个主机,直到我明白我的数据库是MySql .

如果有人可以在这里帮助我,这台主机提供了一个MySql DB,对吗?

我可以使用它来存储数据库并使用JDBC检索我的Android应用程序上的数据吗?

我正在尝试的方式是否正确?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值