借助微信 構(gòu)建 Android Project 編譯通知

dim.red

一 背景

最近萌生一個想法, 在項目編譯成功的時候給自己發(fā)送一條微信.

效果圖.png

二 原理

我們需要跟微信進(jìn)行交互 , 為了達(dá)到這個效果 . 我們在 微信 App 內(nèi)開啟一個 Http 服務(wù). 當(dāng)項目編譯完成以后發(fā)起一個 Http 請求. Http 服務(wù)響應(yīng)這個請求. 將獲取的數(shù)據(jù)轉(zhuǎn)發(fā)發(fā)送給自己 .

三 實現(xiàn)

1 Http 服務(wù).

我們在 WeChatPlugin-MacOS 的基礎(chǔ)上做擴(kuò)展 . 同時使用第三方庫 GCDWebServer 進(jìn)行快速的搭建 Http服務(wù) .

1.1 添加 GCDWebServer 依賴

將原有的 [WeChatPlugin-MacOS] 項目 轉(zhuǎn)換成 cocoapods 管理 .
將 GCDWebServer 添加到 Podfile

platform :osx, '10.10'
inhibit_all_warnings!

target 'WeChatPlugin' do
  pod 'GCDWebServer'
end

1.2 開啟 Http 服務(wù)

WeChatPlugin/sources/Category/WeChat+hook.h

#import <GCDWebServer/GCDWebServer.h>
#import <GCDWebServer/GCDWebServerDataResponse.h>

WeChatPlugin/sources/Category/WeChat+hook.m

static GCDWebServer *server;
+ (void)setup {
   
    server = [[GCDWebServer alloc] init];       
    [server addHandlerForMethod:@"GET" path:@"/wechat/notify" requestClass:[GCDWebServerRequest class] processBlock:^GCDWebServerResponse * _Nullable(__kindof GCDWebServerRequest * _Nonnull request) {
        NSString *msg = [request.query[@"msg"] lowercaseString] ? : @"";
        NSString *currentUserName = [objc_getClass("CUtility") GetCurrentUserName];
        MessageService *service = [[objc_getClass("MMServiceCenter") defaultCenter] getService:objc_getClass("MessageService")];
        [service SendTextMessage:currentUserName toUsrName:currentUserName msgText:msg atUserList:nil];
        return [GCDWebServerDataResponse responseWithJSONObject:@{@"success":@"true"}];
    }];
 
    [server startWithOptions:@{GCDWebServerOption_Port: @(9090),
                                    GCDWebServerOption_BindToLocalhost: @(YES)} error:nil];
    ...
   }

2 發(fā)送 Http 請求

2.1 設(shè)置監(jiān)聽器

/Users/{username}/.gradle 下建立一個文件 init.gradle

allprojects {

    if (project.getProperties().get("notiy", false)) {
        project.pluginManager.withPlugin("com.android.application", {
            def pj = project;
            def projectName = project.rootProject.name + ":" + pj.name;
            def clock = new org.gradle.internal.time.Clock()
            pj.getGradle().addBuildListener(new BuildListener() {

                @Override
                void buildStarted(Gradle gradle) {
                }

                @Override
                void settingsEvaluated(Settings settings) {

                }

                @Override
                void projectsLoaded(Gradle gradle) {

                }

                @Override
                void projectsEvaluated(Gradle gradle) {

                }

                @Override
                void buildFinished(BuildResult result) {

                    boolean isAssembleTask = false
                    pj.android.applicationVariants.each { variant ->
                        if (variant.getAssemble().state.executed) {
                            isAssembleTask = true
                        }
                    }
                    def sp = pj.gradle.startParameter
                    def t = sp.taskNames[0] as String

                    NameMatcher nameMatcher = new NameMatcher()
                    def taskName = nameMatcher.find(t, pj.tasks.asMap.keySet());
                    taskName = taskName == null ? t : taskName;

                    if (isAssembleTask || (result.failure != null && (taskName.startsWith("assemble") || taskName.startsWith("install")))) {
                        String msg;
                        if (result.failure == null) {
                            msg = "項目 : ${projectName} \n任務(wù) : ${taskName} \n編譯 : 成功\n" +
                                    "耗時 : ${clock.elapsed}"
                        } else {
                            msg = "項目 : ${projectName} \n任務(wù) : ${taskName} \n編譯 : 失敗\n" +
                                    "錯誤 : ${result.failure.getMessage()}\n" +
                                    "耗時 : ${clock.elapsed}"
                        }

                        ("curl -X GET   http://localhost:9090/wechat/notify?msg=" +
                                URLEncoder.encode(msg, "UTF-8")).execute()

                    }

                }
            })

        })
    }
}

這里在 gradle init 的時候加入監(jiān)聽 , 監(jiān)聽所有 android 項目的編譯 , 判斷編譯命令中是否包含參數(shù) notiy , 并且 notity 為 true , 如果判斷成功當(dāng)編譯完成 , 使用 curl 將編譯結(jié)果發(fā)送 Http 服務(wù) .

2.2 命令行使用

在原有的編譯命令添加額外參數(shù) -P notiy=true
eg:

  ./gradlew assembleDebug -P notiy=true 

2.3 優(yōu)化

為了優(yōu)化體驗.我們可以將參數(shù)設(shè)置成默認(rèn).
因為 Android 項目的編譯觸發(fā)有兩種方式: 命令行 和 idea . 這里的優(yōu)化也分為兩種情況,
情況一 : 命令行
修改 gradlew 文件末端 , 添加 "-P" "notiy=true"

exec "$JAVACMD" "${JVM_OPTS[@]}" -classpath "$CLASSPATH" org.gradle.wrapper.GradleWrapperMain "$@" "-P" "notiy=true"

情況二 : Idea
配置添加 -P notiy=true

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容