我想将本地主机 mysql 数据库连接到 flutter,但我没有这样做。我尝试了 mysql1 与这些连接:
ConnectionSettings(
host: '10.0.2.2',
port: 3306,
user: 'root',
password: "root",
db: 'company'
我尝试用“localhost”替换主机,但没有成功。有什么帮助吗?我没有使用模拟器。
直接连接到 MySQL(或直接从客户端访问任何其他数据库)并不是一个好主意,Firebase 除外。
如果您想与 MySql 数据库交互,更好的解决方案是创建一个服务器应用程序并公开一些 HTTP REST API(使用 node.js、php 等)。通过 API,您还可以为客户端提供令牌以访问您的数据。
您可以发出 HTTP 请求https://api.dartlang.org/stable/1.24.3/dart-io/HttpClient-class.html https://api.dartlang.org/stable/1.24.3/dart-io/HttpClient-class.html.
现在,如果出于任何原因您仍然想直接连接到 MySQL,请记住,任何客户端应用程序都可以使用以下命令访问您的数据库:write在这种情况下(这根本不是一个好的做法!)仅作为测试示例,您可以尝试创建一个 php 文件:
// 连接并插入数据示例
<?php
if (isset($_POST["value"])) {
$servername = "localhost";
$user = "username";
$pw = "password";
$db = "data";
#Connect to Server
$con = new Mysqli($servername, $user, $pw, $db) or die(Mysqli_errno());
$value =htmlspecialchars(stripslashes(trim($_POST["value"])));
$sql = $con->prepare("INSERT INTO tableName (value) VALUES ('$value')");
$result = $sql->execute();
if ($result) {
echo "Success";
}
else {
echo "Failed";
}
$con->close();
}
else {
echo "Not found";
}
?>
还需要编写在http.post上发出请求的flutter部分
void post() async {
var result = await http.post(
"http://{your url}/index.php",
body: {
"value": "Test DB Connection"
}
);
print(result.body);
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)