用Android程序去直連MySQL數(shù)據(jù)庫(kù),覺(jué)得這樣做不好,出于安全等方面考慮。數(shù)據(jù)庫(kù)地址,用戶(hù)名密碼,查詢(xún)SQL什么的都存在程序里,很容易被反編譯等方法看到。
創(chuàng)新互聯(lián)建站基于成都重慶香港及美國(guó)等地區(qū)分布式IDC機(jī)房數(shù)據(jù)中心構(gòu)建的電信大帶寬,聯(lián)通大帶寬,移動(dòng)大帶寬,多線(xiàn)BGP大帶寬租用,是為眾多客戶(hù)提供專(zhuān)業(yè)服務(wù)器托管報(bào)價(jià),主機(jī)托管價(jià)格性?xún)r(jià)比高,為金融證券行業(yè)四川綿陽(yáng)服務(wù)器托管,ai人工智能服務(wù)器托管提供bgp線(xiàn)路100M獨(dú)享,G口帶寬及機(jī)柜租用的專(zhuān)業(yè)成都idc公司。
建議把表示層和數(shù)據(jù)層邏輯分開(kāi),數(shù)據(jù)層對(duì)應(yīng)網(wǎng)頁(yè)的表示層提供接口,同時(shí)在為Android手機(jī)端提供一個(gè)接口,簡(jiǎn)介訪(fǎng)問(wèn)數(shù)據(jù)庫(kù),這接口可以2端都保持一致,比如XML+RPC或者json等等,Android端也有現(xiàn)成的東西能直接用,既安全又省事。
android 鏈接mysql數(shù)據(jù)庫(kù)實(shí)例:
package com.hl;
import java.sql.DriverManager;
import java.sql.ResultSet;
import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;
public class AndroidMsql extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Button btn=(Button)findViewById(R.id.btn);
btn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
sqlCon();
}
});
}
private void mSetText(String str){
TextView txt=(TextView)findViewById(R.id.txt);
txt.setText(str);
}
private void sqlCon(){
try {
Class.forName("com.mysql.jdbc.Driver");
} catch (Exception e) {
e.printStackTrace();
}
try {
String url ="jdbc:mysql://192.168.142.128:3306/mysql?user=zzfeihuapassword=12345useUnicode=truecharacterEncoding=UTF-8";//鏈接數(shù)據(jù)庫(kù)語(yǔ)句
Connection conn= (Connection) DriverManager.getConnection(url); //鏈接數(shù)據(jù)庫(kù)
Statement stmt=(Statement) conn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR_UPDATABLE);
String sql="select * from user";//查詢(xún)user表語(yǔ)句
ResultSet rs=stmt.executeQuery(sql);//執(zhí)行查詢(xún)
StringBuilder str=new StringBuilder();
while(rs.next()){
str.append(rs.getString(1)+"\n");
}
mSetText(str.toString());
rs.close();
有點(diǎn)多請(qǐng)耐心看完。
希望能幫助你,還請(qǐng)及時(shí)采納謝謝。
一.前言
android連接數(shù)據(jù)庫(kù)的方式有兩種,第一種是通過(guò)連接服務(wù)器,再由服務(wù)器讀取數(shù)據(jù)庫(kù)來(lái)實(shí)現(xiàn)數(shù)據(jù)的增刪改查,這也是我們常用的方式。第二種方式是android直接連接數(shù)據(jù)庫(kù),這種方式非常耗手機(jī)內(nèi)存,而且容易被反編譯造成安全隱患,所以在實(shí)際項(xiàng)目中不推薦使用。
二.準(zhǔn)備工作
1.加載外部jar包
在Android工程中要使用jdbc的話(huà),要導(dǎo)入jdbc的外部jar包,因?yàn)樵贘ava的jdk中并沒(méi)有jdbc的api,我使用的jar包是mysql-connector-java-5.1.18-bin.jar包,網(wǎng)絡(luò)上有使用mysql-connector-java-5.1.18-bin.jar包的,自己去用的時(shí)候發(fā)現(xiàn)不兼容,所以下載了比較新版本的,jar包可以去官網(wǎng)下載,也可以去百度,有很多前人們上傳的。
2.導(dǎo)入jar包的方式
方式一:
可以在項(xiàng)目的build.gradle文件中直接添加如下語(yǔ)句導(dǎo)入
compile files('libs/mysql-connector-java-5.1.18-bin.jar')
方式二:下載jar包復(fù)制到項(xiàng)目的libs目錄下,然后右鍵復(fù)制過(guò)來(lái)的jar包Add as libs
三.建立數(shù)據(jù)庫(kù)連接
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_jdbc);
new Thread(runnable).start();
}
Handler myHandler=new Handler(){
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
super.handleMessage(msg);
Bundle data=new Bundle();
data=msg.getData();
//System.out.println("id:"+data.get("id").toString()); //輸出第n行,列名為“id”的值
Log.e("TAG","id:"+data.get("id").toString());
TextView tv= (TextView) findViewById(R.id.jdbc);
//System.out.println("content:"+data.get("content").toString());
}
};
Runnable runnable=new Runnable() {
private Connection con = null;
@Override
public void run() {
// TODO Auto-generated method stub
try {
Class.forName("com.mysql.jdbc.Driver");
//引用代碼此處需要修改,address為數(shù)據(jù)IP,Port為端口號(hào),DBName為數(shù)據(jù)名稱(chēng),UserName為數(shù)據(jù)庫(kù)登錄賬戶(hù),Password為數(shù)據(jù)庫(kù)登錄密碼
con =
//DriverManager.getConnection("jdbc:mysql://192.168.1.202:3306/b2b", "root", "");
DriverManager.getConnection("jdbc:mysql://",
UserName,Password);
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
try {
testConnection(con); //測(cè)試數(shù)據(jù)庫(kù)連接
} catch (java.sql.SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
public void testConnection(Connection con1) throws java.sql.SQLException {
try {
String sql = "select * from ecs_users"; //查詢(xún)表名為“oner_alarm”的所有內(nèi)容
Statement stmt = con1.createStatement(); //創(chuàng)建Statement
ResultSet rs = stmt.executeQuery(sql); //ResultSet類(lèi)似Cursor
//codeResultSet/code最初指向第一行
Bundle bundle=new Bundle();
while (rs.next()) {
bundle.clear();
bundle.putString("id",rs.getString("userid"));
//bundle.putString("content",rs.getString("content"));
Message msg=new Message();
msg.setData(bundle);
myHandler.sendMessage(msg);
}
rs.close();
stmt.close();
} catch (SQLException e) {
} finally {
if (con1 != null)
try {
con1.close();
} catch (SQLException e) {}
}
}
};
注意:
在Android4.0之后,不允許在主線(xiàn)程中進(jìn)行比較耗時(shí)的操作(連接數(shù)據(jù)庫(kù)就屬于比較耗時(shí)的操作),需要開(kāi)一個(gè)新的線(xiàn)程來(lái)處理這種耗時(shí)的操作,沒(méi)新線(xiàn)程時(shí),一直就是程序直接退出,開(kāi)了一個(gè)新線(xiàn)程處理直接,就沒(méi)問(wèn)題了。
當(dāng)然,連接數(shù)據(jù)庫(kù)是需要網(wǎng)絡(luò)的,千萬(wàn)別忘了添加訪(fǎng)問(wèn)網(wǎng)絡(luò)權(quán)限:
uses-permission android:name=”android.permission.INTERNET”/
四.bug點(diǎn)
1.導(dǎo)入的jar包一定要正確
2.連接數(shù)據(jù)庫(kù)一定要開(kāi)啟新線(xiàn)程
3.數(shù)據(jù)庫(kù)的IP一定要是可以ping通的,局域網(wǎng)地址手機(jī)是訪(fǎng)問(wèn)不了的
4.數(shù)據(jù)庫(kù)所在的服務(wù)器是否開(kāi)了防火墻,阻止了訪(fǎng)問(wèn)
————————————————
版權(quán)聲明:本文為CSDN博主「shuaiyou_comon」的原創(chuàng)文章,遵循CC 4.0 BY-SA版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明。
原文鏈接:
可以使用mysql推出的mysqlconnector/net組件,該組件是mysql為ado.net訪(fǎng)問(wèn)mysql數(shù)據(jù)庫(kù)設(shè)計(jì)的.net專(zhuān)用訪(fǎng)問(wèn)組件,完成該組件后,需要在項(xiàng)目中引用這個(gè)組件,之后在程序中引用命名空間mysql.data.mysqlclient,即可開(kāi)始進(jìn)行連接mysql數(shù)據(jù)庫(kù)的操作了,示例如下:
protected
voidmysqlcon()
{
//數(shù)據(jù)庫(kù)連接字符串跟連接sqlserver沒(méi)有區(qū)別
string
constr
=
"server=localhost;userid=root;password=root;database=test";
//下面使用mysql
connector/net提供的專(zhuān)用對(duì)象
mysqlconnection
mycon
=
new
mysqlconnection(constr);
mycon.open();
mysqlcommandmycmd
=
new
mysqlcommand("select
*
from
users",
mycon);
mysqldatareader
myreader
=
mycmd.executereader();
while
(myreader.read())
{
if
(myreader.hasrows)
{
messagebox.show(myreader.getstring("email")
);
}
}
myreader.close();
mycon.close();
如果mysql支持iPhone話(huà),當(dāng)然可以,不過(guò)一般是把mysql放在后臺(tái)用吧。iPhone通過(guò)網(wǎng)絡(luò)訪(fǎng)問(wèn)后臺(tái)的接口,讓后臺(tái)來(lái)調(diào)用mysql.
1、使用show語(yǔ)句找出在服務(wù)器上當(dāng)前存在什么數(shù)據(jù)庫(kù):
mysql
show
databases;
+----------+
|
database
|
+----------+
|
mysql
|
|
test
|
+----------+
3
rows
in
set
(0.00
sec)
2、創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)abccs
mysql
create
database
abccs;
注意不同操作系統(tǒng)對(duì)大小寫(xiě)的敏感。
3、選擇你所創(chuàng)建的數(shù)據(jù)庫(kù)
mysql
use
abccs
database
changed
此時(shí)你已經(jīng)進(jìn)入你剛才所建立的數(shù)據(jù)庫(kù)abccs.
4、
創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表
首先看現(xiàn)在你的數(shù)據(jù)庫(kù)中存在什么表:
mysql
show
tables;
empty
set
(0.00
sec)
說(shuō)明剛才建立的數(shù)據(jù)庫(kù)中還沒(méi)有數(shù)據(jù)庫(kù)表。下面來(lái)創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)表mytable:
我們要建立一個(gè)你公司員工的生日表,表的內(nèi)容包含員工姓名、性別、出生日期、出生城市。
mysql
create
table
mytable
(name
varchar(20),
sex
char(1),
-
birth
date,
birthaddr
varchar(20));
query
ok,
rows
affected
(0.00
sec)
由于name、birthadd的列值是變化的,因此選擇varchar,其長(zhǎng)度不一定是20。可以選擇從1到255的任何長(zhǎng)度,如果以后需要改變它的字長(zhǎng),可以使用alter
table語(yǔ)句。);性別只需一個(gè)字符就可以表示:"m"或"f",因此選用char(1);birth列則使用date數(shù)據(jù)類(lèi)型。
創(chuàng)建了一個(gè)表后,我們可以看看剛才做的結(jié)果,用show
tables顯示數(shù)據(jù)庫(kù)中有哪些表:
mysql
show
tables;
+---------------------+
|
tables
in
menagerie
|
+---------------------+
|
mytables
|
+---------------------+
5、顯示表的結(jié)構(gòu):
mysql
describe
mytable;
+-------------+-------------+------+-----+---------+-------+
|
field
|
type
|
null
|
key
|
default
|
extra
|
+-------------+-------------+------+-----+---------+-------+
|
name
|
varchar(20)
|
yes
|
|
null
|
|
|
sex
|
char(1)
|
yes
|
|
null
|
|
|
birth
|
date
|
yes
|
|
null
|
|
|
deathaddr
|
varchar(20)
|
yes
|
|
null
|
|
+-------------+-------------+------+-----+---------+-------+
4
rows
in
set
(0.00
sec)
6、
往表中加入記錄
我們先用select命令來(lái)查看表中的數(shù)據(jù):
mysql
select
*
from
mytable;
empty
set
(0.00
sec)
這說(shuō)明剛才創(chuàng)建的表還沒(méi)有記錄。
加入一條新記錄:
mysql
insert
into
mytable
-
values
(′abccs′,′f′,′1977-07-07′,′china′);
query
ok,
1
row
affected
(0.05
sec)
再用上面的select命令看看發(fā)生了什么變化。我們可以按此方法一條一條地將所有員工的記錄加入到表中。
網(wǎng)頁(yè)題目:mysql數(shù)據(jù)庫(kù)手機(jī)版怎么使用,手機(jī)mysql數(shù)據(jù)庫(kù)app下載
標(biāo)題URL:http://muchs.cn/article10/phijdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、建站公司、動(dòng)態(tài)網(wǎng)站、Google、軟件開(kāi)發(fā)、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容