一 背景
最近萌生一個想法, 在項目編譯成功的時候給自己發(fā)送一條微信.
二 原理
我們需要跟微信進(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