要在Android系統(tǒng)中操作SQLite數(shù)據(jù)庫(kù),是通過(guò)Android的核心類(lèi)SQLiteDatabase類(lèi)來(lái)實(shí)現(xiàn)的,通常情況下為了數(shù)據(jù)庫(kù)升級(jí)的需要以及使用方便,會(huì)選擇繼承SQLiteOpenHelper抽像類(lèi),但是SQLiteOpenHelper會(huì)將數(shù)據(jù)庫(kù)文件創(chuàng)建在一個(gè)固定的目錄(內(nèi)存的/data/data/package name/databases目錄中),如果想使用已經(jīng)存在的數(shù)據(jù)庫(kù)文件也就是說(shuō)數(shù)據(jù)庫(kù)會(huì)和程序一起發(fā)布,就得通過(guò)使用SQLiteDabase的靜態(tài)方法OpenOrCreateDatabase()方法來(lái)得到SQLiteDabase對(duì)象,下面是一個(gè)具體操作類(lèi):
創(chuàng)新互聯(lián)公司長(zhǎng)期為成百上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開(kāi)放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為興安企業(yè)提供專(zhuān)業(yè)的成都網(wǎng)站制作、做網(wǎng)站,興安網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開(kāi)發(fā)。
package net.my.dao;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import net.my.jokebook.R;
import android.app.Activity;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
public class DBHelper {
//得到SD卡路徑
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath()
+ "/joke";
private final Activity activity;
//數(shù)據(jù)庫(kù)名
private final String DATABASE_FILENAME;
public DBHelper(Context context) {
// TODO Auto-generated constructor stub
//這里直接給數(shù)據(jù)庫(kù)名
DATABASE_FILENAME = "jokebook.db3";
activity = (Activity)context;
}
//得到操作數(shù)據(jù)庫(kù)的對(duì)象
public SQLiteDatabase openDatabase()
{
try
{
boolean b = false;
//得到數(shù)據(jù)庫(kù)的完整路徑名
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
//將數(shù)據(jù)庫(kù)文件從資源文件放到合適地方(資源文件也就是數(shù)據(jù)庫(kù)文件放在項(xiàng)目的res下的raw目錄中)
//將數(shù)據(jù)庫(kù)文件復(fù)制到SD卡中 File dir = new File(DATABASE_PATH);
if (!dir.exists())
b = dir.mkdir();
//判斷是否存在該文件
if (!(new File(databaseFilename)).exists())
{
//不存在得到數(shù)據(jù)庫(kù)輸入流對(duì)象
InputStream is = activity.getResources().openRawResource(
R.raw.jokebook);
//創(chuàng)建輸出流
FileOutputStream fos = new FileOutputStream(databaseFilename);
//將數(shù)據(jù)輸出
byte[] buffer = new byte[8192];
int count = 0;
while ((count = is.read(buffer)) 0)
{
fos.write(buffer, 0, count);
}
//關(guān)閉資源
fos.close();
is.close();
}
//得到SQLDatabase對(duì)象
SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
databaseFilename, null);
return database;
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
return null;
}
}
寫(xiě)完這個(gè)類(lèi)之后,就能得到SQLiteDatabase對(duì)象,就能對(duì)數(shù)據(jù)庫(kù)操作了。
xutils 。
android中的orm框架,一行代碼就可以進(jìn)行增刪改查;
支持事務(wù),默認(rèn)關(guān)閉;
可通過(guò)注解自定義表名,列名,外鍵,唯一性約束,NOT NULL約束,CHECK約束等(需要混淆的時(shí)候請(qǐng)注解表名和列名);
支持綁定外鍵,保存實(shí)體時(shí)外鍵關(guān)聯(lián)實(shí)體自動(dòng)保存或更新;
自動(dòng)加載外鍵關(guān)聯(lián)實(shí)體,支持延時(shí)加載;
可以參考如下內(nèi)容:
目前android開(kāi)發(fā)剛學(xué)習(xí)了一個(gè)多月,最近開(kāi)始研究三方開(kāi)源框架的用法。了解android開(kāi)發(fā)的人應(yīng)該都會(huì)知道,android的數(shù)據(jù)庫(kù)開(kāi)發(fā)主要用到sqlite(如果這點(diǎn)你不清楚,那這篇文章就直接pass吧)。greenDAO應(yīng)該算是當(dāng)前最火的數(shù)據(jù)庫(kù)開(kāi)源框架了吧,它是一個(gè)移動(dòng)開(kāi)發(fā)的ORM(object / relational mapping)框架,至于ORM是什么,可以百度之,本人理解也不是很深,大概意思就是為懶人設(shè)計(jì)的能夠?qū)?duì)象和關(guān)系以映射的方式表達(dá)出來(lái)。greenDAO就是如此:
greenDAO will do the word for you: it maps Java objects to datebase tables(often called ORM). 這樣開(kāi)發(fā)人員就可以吧精力集中在軟件開(kāi)發(fā)上,減輕了"wrting sql and parsing query results" 等等這些"quite tedious tasks".
總之,一句話,greenDAO就是實(shí)現(xiàn)Java對(duì)象和SQLite Datebase的一個(gè)媒介人,簡(jiǎn)化了SQLite的操作。
注:官方網(wǎng)站
1. 下載greenDAO
要使用肯定要先下載他的軟件包了,官網(wǎng)上有它的連接,對(duì)于marven和gradle環(huán)境直接到serarch.maven.org上下載jar包就好了。
下載的jar導(dǎo)入到工程里面就可以了,通常都是/libs目錄下。
2. 前言
(1)generator --- greenDAO-generator.jar
網(wǎng)上使用說(shuō)明很少,搜到的都是對(duì)于我這個(gè)新人來(lái)說(shuō)看的云里霧里,于是本人就干脆直接看官方文檔,這篇文章也是邊看邊寫(xiě)的,可能會(huì)有些混亂。
在github上下載的實(shí)例源碼以及上面圖中我們都會(huì)發(fā)現(xiàn),會(huì)有一個(gè)generator。比如包里面會(huì)有g(shù)reendao和greendao-generator,示例工程會(huì)有DaoExample和DaoExampleGenerator兩個(gè)工程。之前一直不明白,看了官方文檔終于理解了。
“In order to use greenDao in your project, you need to create a second project, the "generator project". 這個(gè)額外的工程是一個(gè)普通的java工程,而非android工程。它的任務(wù)是生成你希望的java對(duì)象所對(duì)應(yīng)的DAO接口對(duì)象。
(2)核心的class -- greenDAO.jar
DAO的core library(greenDAO.jar)中有以下幾個(gè)核心類(lèi),也是后面比用到的,先來(lái)大概了解下他們的結(jié)構(gòu)吧,不然直接看他們的使用會(huì)云里霧里。
DaoMaster:一看名字就知道它是Dao中的最大的官了。它保存了sqlitedatebase對(duì)象以及操作DAO classes(注意:不是對(duì)象)。其提供了一些創(chuàng)建和刪除table的靜態(tài)方法,其內(nèi)部類(lèi)OpenHelper和DevOpenHelper實(shí)現(xiàn)了SQLiteOpenHelper并創(chuàng)建數(shù)據(jù)庫(kù)的框架。
DaoSession:會(huì)話層。操作具體的DAO對(duì)象(注意:是對(duì)象),比如各種getter方法。
在前面的課程中,隨著對(duì)Android體系的了解,已經(jīng)可以進(jìn)行正常的Android應(yīng)用開(kāi)發(fā)了。在Android開(kāi)發(fā)中,同其他工程開(kāi)發(fā)一樣,也經(jīng)常使用一些提高效率的框架,本文我們做一個(gè)對(duì)比。這些框架,既包括:網(wǎng)絡(luò)請(qǐng)求框架、也包括圖片加載庫(kù)框架、還包括數(shù)據(jù)庫(kù)操作等一些框架,總之,了解和熟悉這些框架,會(huì)對(duì)自己的開(kāi)發(fā)效率有很大的提升和幫助。
網(wǎng)絡(luò)請(qǐng)求框架
1、okHttp
在前文的學(xué)習(xí)中,我們已經(jīng)了解過(guò)okHttp,是一個(gè)常用的網(wǎng)絡(luò)加載庫(kù)。
2、Retrofit
介紹
Retrofit是一個(gè)很不錯(cuò)的網(wǎng)絡(luò)請(qǐng)求庫(kù),該庫(kù)是square開(kāi)源的另外一個(gè)庫(kù),之前的okhttp也是該公司開(kāi)源的。
Retrofit是基于OkHttp封裝的RESTful網(wǎng)絡(luò)請(qǐng)求框架,使用注解的方式配置請(qǐng)求。優(yōu)點(diǎn)是速度快,使用注解,callback函數(shù)返回結(jié)果自動(dòng)包裝成Java對(duì)象。官方自己的介紹說(shuō):
A type-safe REST client for Android and Java
該網(wǎng)絡(luò)框架在github上的地址如下:
要求
Retrofit支持的http方式方式包括 GET/POST/PUT/DELETE/HEAD/PATCH,Retrofit要求Java的版本是1.8+,Android應(yīng)用的API版本應(yīng)該在21+。
依賴
使用Retrofit庫(kù),和其他庫(kù)一樣,首先需要設(shè)置依賴,依然是在build.gradle文件中設(shè)置依賴:
//添加retrofit庫(kù)依賴
implementation ‘com.squareup.retrofit2:retrofit:2.1.0’
//添加gson轉(zhuǎn)換器
implementation ‘com.squareup.retrofit2:converter-gson:2.1.0’
使用
通過(guò)一個(gè)例子,我們可以來(lái)演示該框架的使用步驟:
1、定義請(qǐng)求接口,即程序中都需要什么請(qǐng)求操作
public interface HttpServices {
/**
獲取頭條新聞
@param type 新聞?lì)愋?/p>
@param key apiKey
@return
*/
@GET(“toutiao/index”)
Call getNewsList(@Query(“type”) String type, @Query(“key”) String key);
}
2、實(shí)例化Retrofit對(duì)象,使用的Builder的模式創(chuàng)建,如下代碼所示:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(Constants.BASE_API)
.addConverterFactory(GsonConverterFactory.create())
.build();
注意,這里設(shè)置結(jié)構(gòu)體轉(zhuǎn)換器,是可以直接把網(wǎng)絡(luò)請(qǐng)求回來(lái)的數(shù)據(jù)轉(zhuǎn)換為Java結(jié)構(gòu)體,這里設(shè)置的Gson解析器,因此要引入相應(yīng)的轉(zhuǎn)換器支持庫(kù)。
3、得到接口對(duì)象,自己創(chuàng)建的全局的接口對(duì)象,并調(diào)用相應(yīng)的接口,得到一個(gè)類(lèi)似于請(qǐng)求Call對(duì)象。如下所示:
HttpServices httpServices = retrofit.create(HttpServices.class);
Call newsListCall = httpServices.getNewsList(“top”, Constants.API_KEY);
4、加入到請(qǐng)求隊(duì)列中,并設(shè)置回調(diào)方法:
newsListCall.enqueue(new Callback() {
@Override
public void onResponse(Call call, Response response) {
//網(wǎng)絡(luò)請(qǐng)求成功的回調(diào)方法
List list = Arrays.asList(response.body().result.data);
Log.i(“TAG”, “請(qǐng)求成功:” + String.valueOf(list.size()));
NewListAdapter adapter = new NewListAdapter(RetrofitActivity.this);
adapter.setmData(list);
mRecyclerView.setAdapter(adapter);
}
@Override
public void onFailure(Call call, Throwable throwable) {
//網(wǎng)絡(luò)請(qǐng)求失敗的回調(diào)方法
Log.i(“TAG”, “請(qǐng)求失敗:” + throwable.getMessage());
}
});
其他界面操作和之前的Android中的內(nèi)容一致。
3、RxJava
簡(jiǎn)單來(lái)說(shuō),用來(lái)處理事件和異步任務(wù),在很多語(yǔ)言上都有實(shí)現(xiàn),RxJava是Rx在Java上的實(shí)現(xiàn)。
原理
RxJava最基本的原理是基于觀察者模式來(lái)實(shí)現(xiàn)的。通過(guò)Obserable和Observer的機(jī)制,實(shí)現(xiàn)所謂響應(yīng)式的編程體驗(yàn)。
特點(diǎn)
RxJava在編程中的實(shí)現(xiàn)就是一種鏈?zhǔn)秸{(diào)用,做了哪些操作,誰(shuí)在前誰(shuí)在后非常直觀,邏輯清晰,代碼維護(hù)起來(lái)非常輕松。
RxJava也是一個(gè)在github上的庫(kù),github地址如下:
基于此,還有一個(gè)RxAndroid,github地址如下:
RxJava和RxAndroid的關(guān)系
RxAndroid是RxJava的一個(gè)針對(duì)Android平臺(tái)的擴(kuò)展,主要用于 Android 開(kāi)發(fā)。
基本概念
RxJava 有四個(gè)基本概念:
Observable:可觀察者,即被觀察者Observer:觀察者subscribe:訂閱事件
這四個(gè)概念之間的邏輯關(guān)系是:Observable和Observer通過(guò)subscribe方法實(shí)現(xiàn)訂閱關(guān)系,從而Observable可以在需要的時(shí)候發(fā)出事件來(lái)通知Observer。
事件
RxJava 的事件回調(diào)方法主要包含以下幾個(gè):
onNext:普通的事件onCompleted:事件隊(duì)列完結(jié)。RxJava 不僅把每個(gè)事件單獨(dú)處理,還會(huì)把它們看做一個(gè)隊(duì)列。RxJava 規(guī)定,當(dāng)不會(huì)再有新的 onNext 發(fā)出時(shí),需要觸發(fā) onCompleted 方法作為標(biāo)志。:事件隊(duì)列異常。在事件處理過(guò)程中出異常時(shí), 會(huì)被觸發(fā),同時(shí)隊(duì)列自動(dòng)終止,不再允許再有事件發(fā)出。在一個(gè)正確運(yùn)行的事件序列中, onCompleted和 有且只有一個(gè),并且是事件序列中的最后一個(gè)。需要注意的是,onCompleted() 和 () 二者也是互斥的,即在隊(duì)列中調(diào)用了其中一個(gè),就不應(yīng)該再調(diào)用另一個(gè)。
數(shù)據(jù)庫(kù)操作框架
在開(kāi)發(fā)時(shí),本地?cái)?shù)據(jù)庫(kù)可以起到緩存數(shù)據(jù)和存儲(chǔ)業(yè)務(wù)數(shù)據(jù)的作用,隨著技術(shù)的成熟,不斷推出了有很多關(guān)于數(shù)據(jù)庫(kù)的操作框架。比較常見(jiàn)的數(shù)據(jù)庫(kù)操作框架有諸如:GreenDao,OrmLite 和 ActiveAndroid,DBFlow等。
GreenDAO
GreenDAO是一個(gè)開(kāi)源的 Android ORM(“對(duì)象/關(guān)系映射”),通過(guò) ORM(稱(chēng)為“對(duì)象/關(guān)系映射”),在我們數(shù)據(jù)庫(kù)開(kāi)發(fā)過(guò)程中節(jié)省了開(kāi)發(fā)時(shí)間!
GreenDao的官方文檔地址如下:
GreenDao的作用
通過(guò) GreenDao,我們可以更快速的操作數(shù)據(jù)庫(kù),我們可以使用簡(jiǎn)單的面相對(duì)象的API來(lái)存儲(chǔ),更新,刪除和查詢 Java 對(duì)象。這款數(shù)據(jù)庫(kù)操作框架的特點(diǎn)是:
高性能,在官方的統(tǒng)計(jì)數(shù)據(jù)中,GreenDao在GreenDao,OrmLite 和 ActiveAndroid三個(gè)框架中,讀、寫(xiě)、更新操作效率均表現(xiàn)第一。易于使用的強(qiáng)大 API,涵蓋關(guān)系和連接。內(nèi)存消耗較小。安全:greenDAO 支持 SQLCipher,以確保用戶的數(shù)據(jù)安全;
核心概念
GreenDao 的核心類(lèi)有三個(gè):分別是:
DaoMaster:保存數(shù)據(jù)庫(kù)對(duì)象(SQLiteDatabase)并管理特定模式的 DAO 類(lèi)(而不是對(duì)象)。它有靜態(tài)方法來(lái)創(chuàng)建表或刪除它們。它的內(nèi)部類(lèi) OpenHelper 和DevOpenHelper 是 SQLiteOpenHelper 實(shí)現(xiàn),它們?cè)?SQLite 數(shù)據(jù)庫(kù)中創(chuàng)建模式。DaoSession:管理特定模式的所有可用 DAO 對(duì)象,您可以使用其中一個(gè)getter方法獲取該對(duì)象。DaoSession 還提供了一些通用的持久性方法,如實(shí)體的插入,加載,更新,刷新和刪除。XXXDao:數(shù)據(jù)訪問(wèn)對(duì)象(DAO)持久存在并查詢實(shí)體。對(duì)于每個(gè)實(shí)體,greenDAO 生成DAO。它具有比 DaoSession 更多的持久性方法。Entities:可持久化對(duì)象。通常, 實(shí)體對(duì)象代表一個(gè)數(shù)據(jù)庫(kù)行使用標(biāo)準(zhǔn) Java 屬性(如一個(gè)POJO 或 JavaBean )。
使用
按照官方的文檔和github上的說(shuō)明可以實(shí)現(xiàn)greendao的使用。
首先進(jìn)行的是依賴,對(duì)于greenDao,有兩個(gè)地方需要設(shè)置,分別是項(xiàng)目根目錄中的 build.gradle,還有module中的build.gradle。
classpath ‘org.greenrobot:greendao-gradle-plugin:3.3.0’ // add plugin
在項(xiàng)目根目錄中的build.gradle目錄中寫(xiě)這句話的意思是添加greenDao的插件。
在項(xiàng)目module中的build.gradle中也需要進(jìn)行配置,有兩個(gè)地方需要設(shè)置,如下圖所示:
apply plugin: ‘org.greenrobot.greendao’ //開(kāi)頭加入該代碼
dependences{
implementation ‘org.greenrobot:greendao:3.2.0’
}
然后就可以使用了。
bean實(shí)體
可以在項(xiàng)目中創(chuàng)建自己業(yè)務(wù)需要的實(shí)體類(lèi),并通過(guò)注解來(lái)設(shè)置是實(shí)體類(lèi),字段約束等內(nèi)容。然后點(diǎn)擊Android Studio中的Make module,即可自動(dòng)生成XXXDao代碼,以此來(lái)方便開(kāi)發(fā)者的操作。生成的XXXDao類(lèi),不可修改和編輯,是自動(dòng)生成的。
ORMLite
ORMLite框架是另外一款A(yù)ndroid開(kāi)發(fā)中可以使用的數(shù)據(jù)庫(kù)操作框架。該框架的文檔地址如下:
該框架的文檔準(zhǔn)備的不是特別友好,此處不再贅述。
總結(jié),所有的框架原理幾乎都相差不大,只是操作有所差異。
視圖注入框架
在Android項(xiàng)目開(kāi)發(fā)過(guò)程中,有太多的頁(yè)面需要布局完成,同時(shí)在代碼中需要些大量的findviewbyid的操作,來(lái)實(shí)現(xiàn)控件的解析。于是就有人想能否輕松一些,解放雙手節(jié)省時(shí)間,干一些其他有意義的事情,于是ButterKnife就來(lái)了。
ButterKnife是一個(gè)專(zhuān)注于Android系統(tǒng)的View注入框架,可以減少大量的findViewById以及setOnClickListener代碼,可視化一鍵生成。
該項(xiàng)目在github上的地址如下:
這個(gè)框架的優(yōu)勢(shì)也非常明顯:
強(qiáng)大的View綁定和Click事件處理功能,簡(jiǎn)化代碼,提升開(kāi)發(fā)效率方便的處理Adapter里的ViewHolder綁定問(wèn)題運(yùn)行時(shí)不會(huì)影響APP效率,使用配置方便代碼清晰,可讀性強(qiáng)
使用
首先是設(shè)置依賴,在build.gradle中進(jìn)行依賴設(shè)置:
implementation ‘com.jakewharton:butterknife:10.2.1’
annotationProcessor ‘com.jakewharton:butterknife-compiler:10.2.1’
需要注意,該框架要求Java環(huán)境1.8版本以上,SDK版本在26以上,因此在使用到的module中的build.graldle文件中,還必須添加如下代碼配置:
apply plugin: ‘com.jakewharton.butterknife’
android{
//…
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
//…
}
另外,還必須在項(xiàng)目根目錄中的build.gradle文件中,添加該框架的插件,如下圖所示:
dependences{
classpath ‘com.jakewharton:butterknife-gradle-plugin:10.2.1’
}
然后即可在代碼中進(jìn)行使用了。
在使用該框架的頁(yè)面進(jìn)行綁定諸如,如下所示代碼:
ButterKnife.bind( this) ;
主要的功能
@BindView():控件id 注解,解放雙手,不用再每個(gè)控件都寫(xiě)一遍findviewById@BindViews():多個(gè)控件id 的注解,括號(hào)內(nèi)使用花括號(hào)包括多個(gè)id即可,中間用,分割開(kāi)在Fragment中使用,綁定Fragment。@BindString():綁定字符串@BindArray:綁定數(shù)組@BindBitmap:綁定bitmap資源@OnClick、@OnLongClick:綁定點(diǎn)擊事件和長(zhǎng)按事件…還有很多
插件安裝
如果是頁(yè)面很復(fù)雜,一個(gè)一個(gè)寫(xiě)B(tài)indView也很費(fèi)勁,在Android Studio中,可以安裝一個(gè)ButterKnife的插件,安裝該插件后,可以在Studio中直接將對(duì)應(yīng)的布局中的所有控件均給自動(dòng)生成。
注意,在進(jìn)行自動(dòng)生成時(shí),鼠標(biāo)要放在布局文件上。
注意事項(xiàng)
ButterKnife框架在使用時(shí),要求的版本比較高,包括Java的版本也有限制。因此,如果計(jì)劃在項(xiàng)目中使用,要提前做好預(yù)備工作,以防止對(duì)已有項(xiàng)目和業(yè)務(wù)帶來(lái)不必要的麻煩,反而影響工作進(jìn)度。
主要有以下模塊:
(1) 自動(dòng)注入框架(只需要繼承框架內(nèi)的application既可)
(2)
圖片加載框架(多重緩存,自動(dòng)回收,最大限度保證內(nèi)存的安全性)
(3) 網(wǎng)絡(luò)請(qǐng)求模塊(繼承了基本上現(xiàn)在所有的http請(qǐng)求)
(4)
eventbus(集成一個(gè)開(kāi)源的框架)
(5) 驗(yàn)證框架(集成開(kāi)源框架)
(6) json解析(支持解析成集合或者對(duì)象)
(7) 數(shù)據(jù)庫(kù)(不知道是哪位寫(xiě)的 忘記了)
(8) 多線程斷點(diǎn)下載(自動(dòng)判斷是否支持多線程,判斷是否是重定向)
(9)
自動(dòng)更新模塊
(10) 一系列工具類(lèi)
建表,你要寫(xiě)一個(gè)建表語(yǔ)句,即
create table ();
然后讓sqlite去執(zhí)行。
新聞名稱(chēng):android數(shù)據(jù)庫(kù)框架,android的框架
網(wǎng)站路徑:http://m.rwnh.cn/article46/phjhhg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、企業(yè)網(wǎng)站制作、關(guān)鍵詞優(yōu)化、定制網(wǎng)站、網(wǎng)站導(dǎo)航、服務(wù)器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)