Android Studio MainActivity类无法连接到本地Mysql Workbench

问题描述 投票:0回答:1
package com.example.test

import android.os.Bundlemportandroid.view.Menu
import android.view.MenuItem
import androidx.appcompat.app.AppCompatActivity
import com.google.android.material.snackbar.Snackbar
import kotlinx.android.synthetic.main.activity_main.*
import kotlinx.android.synthetic.main.content_main.*
import java.sql.DriverManager
import com.mysql.jdbc.Driver
import java.sql.PreparedStatement
import java.sql.Connection


class MainActivity: AppCompatActivity() {
    override fun onCreate(savedInstanceState: Bundle ? ) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)
        btnDB.setOnClickListener {
            DBConn.DBString()
        }
        setSupportActionBar(toolbar)
        fab.setOnClickListener {
            view - >
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                .setAction("Action", null)
                .show()
        }
    }
    override fun onCreateOptionsMenu(menu: Menu): Boolean {
        // Inflate the menu; this adds items to the action bar if it is present.
        menuInflater.inflate(R.menu.menu_main, menu)
        return true
    }
    override fun onOptionsItemSelected(item: MenuItem): Boolean {
        // 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.
        return when(item.itemId) {
            R.id.action_settings - > true
            else - > super.onOptionsItemSelected(item)
        }
    }
    fun DBCon() {
        try {
            val url = "jdbc:mysql://localhost:3306/Boxing"
            var conn: Connection = DriverManager.getConnection(url, "root", "Guru9")
            //conn.close();
            if (conn != null) {
                println("Connected successfully to Database")
            }
        } catch (e: Exception) {
            println(" Not connected to Database")
        }
    }
}
java android mysql kotlin
1个回答
0
投票

您是在仿真器中还是在真实设备中运行此应用?

检查此行:

val url = "jdbc:mysql://localhost:3306/Boxing"

[我猜您的MySQL服务器正在开发的同一台计算机上运行,​​当应用程序在仿真器中运行时,您将拥有一个IP,例如10.0.XX,因此您看不到此localhost,而在实际设备中运行时可能是IP类似于192.168.XX,请尝试将本地主机替换为IP(而不是127.0.0.1),并尝试使用开发计算机的IP]

© www.soinside.com 2019 - 2024. All rights reserved.