电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術(shù)文章
文章詳情頁

Android Studio,使用技巧,問題記錄和一些好用的插件

瀏覽:85日期:2022-09-27 10:49:23
使用技巧 根據(jù)不同 buildType 使用不同包名和資源

比如在 production,development,qa 不同階段使用不同的 packageName 和 authority,在 build.gradle 中配置如下:

productFlavors {production { applicationId = 'com.myapp.app' resValue 'string', 'authority', 'com.facebook.app.FacebookContentProvider5435651423234'}development { applicationId = 'com.myapp.development' resValue 'string', 'authority', 'com.facebook.app.FacebookContentProvider2134564533421'}qa { applicationId = 'com.myapp.qa' resValue 'string', 'authority', 'com.facebook.app.FacebookContentProvider29831237981287319'}}

通過 resValue 方法設(shè)置的資源會(huì)在 R 文件生成對應(yīng)的 id。

在 AndroidManifest.xml 中使用 authority 字符串

<provider android:name='com.facebook.FacebookContentProvider' android:authorities='@string/authority' android:exported='true' /> 替換 AndroidManifest.xml 中的占位符

使用 manifestPlaceholders 可以定義相關(guān)字段替換 AndroidManifest.xml 中的占位符。

格式:manifestPlaceholders = [ key1:'value1', key2:'value2', ... ]

下面是一個(gè)示例:

android { defaultConfig {def authorityName = 'com.linchaolong.android.app.droidplugin_stub'manifestPlaceholders = [ authorityName:'${authorityName}', key:'value',] }}

說明:manifestPlaceholders 是一個(gè) map。

在 AndroidManifest.xml 中通過 ${key} 引用相關(guān)字段。

自定義 BuildConfig 字段

通過 buildConfigField 可以添加自定義的字段到 BuildConfig 中。

格式:buildConfigField 'type', 'key', 'value'

android { defaultConfig{def authority = 'com.linchaolong.android.app'buildConfigField 'String', 'AUTHORITY', ''${authority }''buildConfigField 'int', 'FOO', '42'buildConfigField 'String', 'FOO_STRING', ''foo''buildConfigField 'boolean', 'LOG', 'true' }}

def 操作符可用于定義變量和函數(shù)。

在 java 代碼中你可以通過 BuildConfig.key 訪問對應(yīng)的字段,比如: BuildConfig.AUTHORITY 訪問 AUTHORITY 常量。

統(tǒng)一管理不同 module 依賴庫的版本

新建一個(gè) config.gradle 在工程根目錄下,并添加一些全局的配置:

allprojects {repositories { jcenter()}ext{ compileSdkVersion = 25 buildToolsVersion = '25.0.0' minSdkVersion = 14 targetSdkVersion = 25 support = ’25.0.0’ play_services = ’9.8.0’ rxjava = ’2.0.1’ // Json gson = ’2.8.0’ // HTTP okhttp = ’3.4.1’ retrofit = ’2.1.0’ glide = ’3.7.0’ // DEPS INJECTION dagger = ’2.6’ // VIEW INJECTION butterknife = ’8.4.0’ // DEBUG stetho = ’1.4.1’}}

然后在 project-level 下的 build.gradle 添加如下配置應(yīng)用 config.gradle :

apply from: rootProject.file(’config.gradle’)

在各 module 的 build.gradle 引用 ext 中的字段

在 android 塊中引用 ext 中的字段

android {compileSdkVersion project.ext.compileSdkVersionbuildToolsVersion project.ext.buildToolsVersiondefaultConfig { applicationId 'linchaolong.demo' minSdkVersion project.ext.minSdkVersion targetSdkVersion project.ext.targetSdkVersion def QQ_APPID = rootProject.ext.QQ_APPID manifestPlaceholders = [QQ_APPID:'${QQ_APPID}']}}

在 dependencies 塊下引用 ext 中的字段

dependencies {compile 'com.android.support:appcompat-v7:$support'// Debugcompile 'com.facebook.stetho:stetho:$stetho'compile 'com.facebook.stetho:stetho-okhttp3:$stetho'debugCompile 'com.facebook.stetho:stetho-js-rhino:$stetho'// Jsoncompile 'com.google.code.gson:gson:$gson'// Butterknifecompile 'com.jakewharton:butterknife:$butterknife'annotationProcessor 'com.jakewharton:butterknife-compiler:$butterknife'// RxJavacompile 'io.reactivex.rxjava2:rxjava:$rxjava'compile 'io.reactivex.rxjava2:rxandroid:$rxjava'}

嚴(yán)重注意:引用 ext 中字段時(shí)要使用雙引號,不能是單引號。格式為 ${key} 或 $key

建立各 Module 共享的配置

比如,這里想統(tǒng)一設(shè)置各 Module 支持的 so 庫架構(gòu),可以在工程目錄下新建一個(gè) module.gradle 存放共享的配置,配置如下:

// Module 共享的配置android { defaultConfig { ndk { //設(shè)置支持的SO庫架構(gòu) abiFilters ’armeabi-v7a’ //, ’armeabi’ , ’x86’, ’x86_64’, ’arm64-v8a’ } }}

然后,在各 Module 下的 build.gradle 配置中應(yīng)用 module.gradle,示例如下:

apply plugin: ’com.android.application’apply from: rootProject.file(’module.gradle’) 自定義 release apk 名稱

修改 build.gradle 配置如下:

android { buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile(’proguard-android.txt’), ’proguard-rules.pro’ signingConfig signingConfigs.release // 自定義 release apk 名稱 applicationVariants.all { variant ->variant.outputs.each { output -> def releaseTime = new Date().format(’yyyyMMddHHmmss’) // 修改 release apk 名稱,app_1.0_20170108224145.apk def fileName = output.outputFile.name.replace('-release', '_${defaultConfig.versionName}_'+releaseTime) output.outputFile = new File(output.outputFile.parent, fileName)} } } }} 手動(dòng) build 工程

我們應(yīng)該都或多或少遇到過這種情況,當(dāng)我們第一次打開一個(gè)項(xiàng)目時(shí),該項(xiàng)目會(huì)先下載相關(guān)的依賴項(xiàng),如果很多的話,將會(huì)等很久,而且又不能做其他操作,這樣太浪費(fèi)時(shí)間了。

Android Studio,使用技巧,問題記錄和一些好用的插件

Image

下面說說如何在命令行中手動(dòng) build 工程:

每個(gè) android studio 工程下應(yīng)該都會(huì)有 gradlew.bat (Windows) 和 gradlew (Mac) 兩個(gè)腳本文件,我們可以打開命令行,cd 到工程目錄下,通過執(zhí)行 gradlew.bat build 命令,手動(dòng)去構(gòu)建工程。

Android Studio,使用技巧,問題記錄和一些好用的插件

Image

通過在命令行構(gòu)建工程可以不影響當(dāng)前工作,而且構(gòu)建完成后再使用 android studio 打開該工程將會(huì)比較快。

手動(dòng)下載和替換本地 gradle/jar

build 過程很慢?這個(gè)多數(shù)是由于個(gè)別依賴項(xiàng)下載速度過慢引起的,有時(shí)還會(huì)卡在某個(gè)點(diǎn),但我們可以通過手動(dòng)下載替換解決該問題。

這里分為兩個(gè)部分,一個(gè)是 gradle 的下載替換,一個(gè)是依賴庫的下載替換。

我們通過在命令行執(zhí)行 gradlew.bat build 命令可以看到相關(guān)依賴的下載地址:

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

正常下載速度可能只有幾十KB(可能更低...),但是如果我們把下載鏈接 copy 到迅雷下載,它是這樣的:

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

在 windows 下,gradle 存放目錄就在 C:Users用戶名.gradlewrapperdists 下。下載完成后,把 *.lck 和 *.zip.part 文件刪掉,替換為我們剛下載的 .zip 。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

重新執(zhí)行 gradlew.bat build 命令可以看到它將會(huì)自動(dòng)解壓該 *.zip 文件。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

在 windows 下,依賴庫的存放目錄就在 C:Users用戶名.gradlecaches 。jar文件的下載替換也是同理,比如我這里下載一個(gè) common-25.3.0-alpha2.jar ,下載完成后把它放在 common-25.3.0-alpha2.pom 同級目錄下,重新執(zhí)行 build 命令即可。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

這里的目錄路徑可能和你的不太一樣,可以使用 Everything 搜索一下文件名。

構(gòu)建一個(gè)aar文件

如果你的 module 聲明為 android library(即在 build.gradle 文件中使用 apply plugin:’com.android.library’ ),它將在構(gòu)建時(shí)輸出 .aar 文件,在 module 的 build/outputs/aar 目錄下。

你可以選擇該 module ,然后 Build —> Make Module * 構(gòu)建該 module。或者使用 gradlew.bat build 命令構(gòu)建工程。然后就可以在輸出目錄下找到 .aar 文件了。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

引用 aar 文件

假設(shè)把 aar 文件放在 module 下的 libs 目錄。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

引用本 module 的 aar 文件 build.gradle 配置如下:

repositories{ flatDir{ dirs ’libs’ }}dependencies { compile(name:’stetho_realm-release’, ext:’aar’)}

如果是引用其他 module 的 aar 文件,還要在本 module 的 build.gradle 中配置被引用 module 的 aar 目錄,否則會(huì)找不到文件。

repositories { flatDir { dirs project(’:Library’).file(’libs’) }}

多個(gè)目錄使用 “,” 分隔

快捷鍵

由于 Android Studio 是基于 IDEA 的,所以很多快捷鍵是通用的。

全局替換

Edit —&gt; Find —&gt; Replace in Path

Android Studio,使用技巧,問題記錄和一些好用的插件

Replace in Path

動(dòng)態(tài)調(diào)試app

1.在源碼先打斷點(diǎn),點(diǎn)擊掛接 Android 進(jìn)程按鈕。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

2.選擇 app 進(jìn)程,點(diǎn)OK,開始調(diào)試。

Android Studio,使用技巧,問題記錄和一些好用的插件

Paste_Image.png

一些好用的插件

插件安裝說明:

在線安裝 打開 File ——> Settings ——> Plugins ——> Browse repositories... 搜索插件名,點(diǎn) Install 下載安裝,安裝完成后重啟生效。 離線安裝 下載插件安裝包,打開 File ——> Settings ——> Plugins ——> Install plugin from disk... 選擇插件安裝包,安裝完成后重啟生效。 GsonFormat

GsonFormat 是一個(gè)可以快速將 JSON 字符串轉(zhuǎn)換為 Entity 類的插件。

Android Studio,使用技巧,問題記錄和一些好用的插件

GsonFormat

使用說明: Alt + S 調(diào)出 GsonFormat,或者 Alt Insert + GsonFormat 。

在 Settings 中選擇 filed(public) ,Enter 保存修改,可以只生成 public 字段,不生成一大堆的 getter 和 setter,代碼會(huì)更簡潔些。

插件地址: https://plugins.jetbrains.com/idea/plugin/7654-gsonformat

Github地址: https://github.com/zzz40500/GsonFormat

Android ButterKnife Zelezny

Android ButterKnife Zelezny 是 Android 下的注解框架 ButterKnife 的輔助插件,用于一鍵生成 Butterknife 視圖注入代碼。

Android Studio,使用技巧,問題記錄和一些好用的插件

Android ButterKnife Zelezny

使用說明:把光標(biāo)停在 setContentView(R.layout.activity_settings) 那行中的 activity_settings 上右鍵選擇 Generate ( alt + insert )→ Generate Butterknife Injections

注意:需要把光標(biāo)停在 layout 的名稱上才能調(diào)出 ButterKnife Zelezny 。

ButterKnife: https://github.com/JakeWharton/butterknife

插件地址: https://plugins.jetbrains.com/idea/plugin/7369-android-butterknife-zelezny

Github地址: https://github.com/avast/android-butterknife-zelezny

ECTranslation

Android Studio 翻譯插件,可以將英文翻譯為中文。

Android Studio,使用技巧,問題記錄和一些好用的插件

ECTranslation

使用說明:選中要翻譯的內(nèi)容,選擇 Edit ——> Translate 或者按下 command + I (我這里設(shè)置為 Shift + I )。

修改快捷鍵: Preferences -> Keymap -> 搜索Translate - > 右鍵 add Keyboard Shortcut . 輸入你想要的快捷鍵即可。

插件地址: https://plugins.jetbrains.com/idea/plugin/8469-ectranslation

Github地址: https://github.com/Skykai521/ECTranslation

問題記錄 Error:The number of method references in a .dex file cannot exceed 64K.

這是錯(cuò)誤是因?yàn)閼?yīng)用的方法數(shù)已經(jīng)超過了64K了,在 class 轉(zhuǎn)換 dex 文件時(shí)報(bào)錯(cuò)了。一個(gè) dex 文件的最大方法數(shù)是65536,所以這時(shí)候要啟用 Multidex。

1.app 的 build.gradle 添加如下配置

android { defaultConfig {// 啟用 multidex 支持.multiDexEnabled true }}dependencies { compile ’com.android.support:multidex:1.0.1’}

2.在 AndroidManifest.xml 下配置 MultiDexApplication

<?xml version='1.0' encoding='utf-8'?><manifest xmlns:android='http://schemas.android.com/apk/res/android' package='com.example.android.multidex.myapplication'> <application...android:name='android.support.multidex.MultiDexApplication'>... </application></manifest>

如果是自定義了 Application 則讓其繼承 MultiDexApplication。

官方文檔: https://developer.android.com/tools/building/multidex.html

Error: '*' is not translated in 'en' (English) [MissingTranslation]

這種錯(cuò)誤一般出現(xiàn)在打包的時(shí)候,表示 strings.xml 中缺失本地化的字符串資源。

這個(gè)錯(cuò)誤有兩個(gè)解決方案:

在 valuesstrings.xml 或出問題的 strings.xml 中添加如下配置:

<resources xmlns:tools='http://schemas.android.com/tools' tools:locale='en'> 在 valuesstrings.xml 或出問題的 strings.xml 中添加如下配置:

<resources xmlns:tools='http://schemas.android.com/tools' tools:ignore='MissingTranslation' >

缺失的本地化字符串資源會(huì)使用默認(rèn)字符串資源。

Could not find Library

日志如下:

Error:A problem occurred configuring project ’:app’.> Could not resolve all dependencies for configuration ’:app:_debugCompile’. > Could not find com.android.support:appcompat-v7:22.2.0. Searched in the following locations: https://jcenter.bintray.com/com/android/support/appcompat-v7/22.2.0/appcompat-v7-22.2.0.pom https://jcenter.bintray.com/com/android/support/appcompat-v7/22.2.0/appcompat-v7-22.2.0.jar file:/D:/AndroidDeveloper/adt-bundle-windows-x86-20130917/sdk/extras/google/m2repository/com/android/support/appcompat-v7/22.2.0/appcompat-v7-22.2.0.pom file:/D:/AndroidDeveloper/adt-bundle-windows-x86-20130917/sdk/extras/google/m2repository/com/android/support/appcompat-v7/22.2.0/appcompat-v7-22.2.0.jar Required by: HelloWorld:app:unspecified

解決辦法:更新你的 Android Support Library 和 Android Support Repository.

修改 applicationId 后啟動(dòng)出現(xiàn)ClassNotFoundException

日志如下:

E/AndroidRuntime: FATAL EXCEPTION: main Process: com.linchaolong.android.app, PID: 10690 java.lang.RuntimeException: Unable to instantiate application com.android.tools.fd.runtime.BootstrapApplication: java.lang.IllegalStateException: java.lang.ClassNotFoundException: com.linchaolong.android.app.MyApplication at android.app.LoadedApk.makeApplication(LoadedApk.java:565) at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4545) at android.app.ActivityThread.access$1500(ActivityThread.java:154) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1369) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:135) at android.app.ActivityThread.main(ActivityThread.java:5275) at java.lang.reflect.Method.invoke(Native Method) at java.lang.reflect.Method.invoke(Method.java:372) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:909) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:704) Caused by: java.lang.IllegalStateException: java.lang.ClassNotFoundException: com.linchaolong.demo.App at com.android.tools.fd.runtime.BootstrapApplication.createRealApplication(BootstrapApplication.java:220) at com.android.tools.fd.runtime.BootstrapApplication.attachBaseContext(BootstrapApplication.java:239) at android.app.Application.attach(Application.java:185) at android.app.Instrumentation.newApplication(Instrumentation.java:996) at android.app.Instrumentation.newApplication(Instrumentation.java:980) at android.app.LoadedApk.makeApplication(LoadedApk.java:560) at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4545)at android.app.ActivityThread.access$1500(ActivityThread.java:154)at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1369)at android.os.Handler.dispatchMessage(Handler.java:102)at android.os.Looper.loop(Looper.java:135)at android.app.ActivityThread.main(ActivityThread.java:5275)at java.lang.reflect.Method.invoke(Native Method)at java.lang.reflect.Method.invoke(Method.java:372)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:909)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:704) Caused by: java.lang.ClassNotFoundException: com.linchaolong.android.app.MyApplication at java.lang.Class.classForName(Native Method) at java.lang.Class.forName(Class.java:306) at java.lang.Class.forName(Class.java:270) at com.android.tools.fd.runtime.BootstrapApplication.createRealApplication(BootstrapApplication.java:209) at com.android.tools.fd.runtime.BootstrapApplication.attachBaseContext(BootstrapApplication.java:239)at android.app.Application.attach(Application.java:185)at android.app.Instrumentation.newApplication(Instrumentation.java:996)at android.app.Instrumentation.newApplication(Instrumentation.java:980)at android.app.LoadedApk.makeApplication(LoadedApk.java:560)at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4545)at android.app.ActivityThread.access$1500(ActivityThread.java:154)at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1369)at android.os.Handler.dispatchMessage(Handler.java:102)at android.os.Looper.loop(Looper.java:135)at android.app.ActivityThread.main(ActivityThread.java:5275)at java.lang.reflect.Method.invoke(Native Method)at java.lang.reflect.Method.invoke(Method.java:372)at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:909)at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:704) Caused by: java.lang.ClassNotFoundException: Didn’t find class 'com.linchaolong.android.app.MyApplication' on path: DexPathList[[zip file

原因是 Android Studio 的 Instant Run 嘗試對你的代碼執(zhí)行熱交換,導(dǎo)致 Application 類被移除所以出現(xiàn) ClassNotFoundException。

停用 Instant Run, File --> Settings--> Build,Execution,Deployment -->Instant Run ---> 取消勾選 'Enable instant run'

相關(guān)文章 Intellij IDEA使用技巧整理 Android Studio各種快捷功能及好用的插件 tools 屬性參考文檔

來自:https://juejin.im/entry/58bfd80ea22b9d00588c3444

標(biāo)簽: Android
相關(guān)文章:
主站蜘蛛池模板: 波纹补偿器_不锈钢波纹补偿器_巩义市润达管道设备制造有限公司 | 科普仪器菏泽市教育教学仪器总厂 | 办公室家具公司_办公家具品牌厂家_森拉堡办公家具【官网】 | 天津市能谱科技有限公司-专业的红外光谱仪_红外测油仪_紫外测油仪_红外制样附件_傅里叶红外光谱技术生产服务厂商 | 北京四合院出租,北京四合院出售,北京平房买卖 - 顺益兴四合院 | 鹤壁创新仪器公司-全自动量热仪,定硫仪,煤炭测硫仪,灰熔点测定仪,快速自动测氢仪,工业分析仪,煤质化验仪器 | 重庆磨床过滤机,重庆纸带过滤机,机床伸缩钣金,重庆机床钣金护罩-重庆达鸿兴精密机械制造有限公司 | 成都珞石机械 - 模温机、油温机、油加热器生产厂家 | 环球周刊网| 便携式高压氧舱-微压氧舱-核生化洗消系统-公众洗消站-洗消帐篷-北京利盟救援 | 消电检公司,消电检价格,北京消电检报告-北京设施检测公司-亿杰(北京)消防工程有限公司 | 压砖机_电动螺旋压力机_粉末成型压力机_郑州华隆机械tel_0371-60121717 | RO反渗透设备_厂家_价格_河南郑州江宇环保科技有限公司 | 深圳办公室装修,办公楼/写字楼装修设计,一级资质 - ADD写艺 | 自清洗过滤器,浅层砂过滤器,叠片过滤器厂家-新乡市宇清净化 | 上海三信|ph计|酸度计|电导率仪-艾科仪器 | 胀套-锁紧盘-风电锁紧盘-蛇形联轴器「厂家」-瑞安市宝德隆机械配件有限公司 | 玻璃钢型材-玻璃钢风管-玻璃钢管道,生产厂家-[江苏欧升玻璃钢制造有限公司] | 集菌仪_智能集菌仪_全封闭集菌仪_无菌检查集菌仪厂家-那艾 | 折弯机-刨槽机-数控折弯机-数控刨槽机-数控折弯机厂家-深圳豐科机械有限公司 | 阳光1号桔柚_无核沃柑_柑橘新品种枝条苗木批发 - 苧金网 | 智能化的检漏仪_气密性测试仪_流量测试仪_流阻阻力测试仪_呼吸管快速检漏仪_连接器防水测试仪_车载镜头测试仪_奥图自动化科技 | 南昌旅行社_南昌国际旅行社_南昌国旅在线 | 氧化锆纤维_1800度高温退火炉_1800度高温烧结炉-南京理工宇龙新材料股份有限公司 | 青州开防盗门锁-配汽车芯片钥匙-保险箱钥匙-吉祥修锁店 | 密集柜_档案密集柜_智能密集架_密集柜厂家_密集架价格-智英伟业 密集架-密集柜厂家-智能档案密集架-自动选层柜订做-河北风顺金属制品有限公司 | 郑州水质检测中心_井水检测_河南废气检测_河南中环嘉创检测 | 船老大板材_浙江船老大全屋定制_船老大官网 | 回转支承-转盘轴承-回转驱动生产厂家-洛阳隆达轴承有限公司 | 南京雕塑制作厂家-不锈钢雕塑制作-玻璃钢雕塑制作-先登雕塑厂 | 喷砂机厂家_自动除锈抛丸机价格-成都泰盛吉自动化喷砂设备 | 药品仓库用除湿机-变电站用防爆空调-油漆房用防爆空调-杭州特奥环保科技有限公司 | 德国进口电锅炉_商用电热水器_壁挂炉_电采暖器_电热锅炉[德国宝] | 冷凝水循环试验箱-冷凝水试验箱-可编程高低温试验箱厂家-上海巨为(www.juweigroup.com) | EDLC超级法拉电容器_LIC锂离子超级电容_超级电容模组_软包单体电容电池_轴向薄膜电力电容器_深圳佳名兴电容有限公司_JMX专注中高端品牌电容生产厂家 | 常州减速机_减速机厂家_常州市减速机厂有限公司 | 青岛美佳乐清洁工程有限公司|青岛油烟管道清洗|酒店|企事业单位|学校工厂厨房|青岛油烟管道清洗 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | 金蝶帐无忧|云代账软件|智能财税软件|会计代账公司专用软件 | 塑料薄膜_PP薄膜_聚乙烯薄膜-常州市鑫美新材料包装厂 | 涂层测厚仪_光泽度仪_uv能量计_紫外辐照计_太阳膜测试仪_透光率仪-林上科技 | 三氯异氰尿酸-二氯-三氯-二氯异氰尿酸钠-优氯净-强氯精-消毒片-济南中北_优氯净厂家 |