从本质上讲,您必须在ex3ndr/telegram-api存储库中填写GitHub上给出的代码中的空白。如果您已经将构建的库 Jar 文件和该文件放在 Eclipse 项目的 Java 构建路径上,请查看自述文件的 RPC 调用部分,然后查看tl-api-v12.jar
首先,您需要使用API凭证设置一个对象,然后您还必须创建一些实现和接口的新类。一旦这些可用,您就可以创建对象并对电报服务进行RPC调用,如下所示;在这种情况下,使用建议的auth.checkPhone
方法:AppInfo
AbsApiState
ApiCallback
TelegramApi
// TODO set up AbsApiState, AppInfo and ApiCallback objects
TelegramApi api = new TelegramApi(state, appInfo, apiCallback);
// Create request
String phoneNumber = "1234567890";
TLRequestAuthCheckPhone checkPhone = new TLRequestAuthCheckPhone(phoneNumber);
// Call service synchronously
TLCheckedPhone checkedPhone = api.doRpcCall(checkPhone);
boolean invited = checkedPhone.getPhoneInvited();
boolean registered = checkedPhone.getPhoneRegistered();
// TODO process response further
该对象表示您与远程服务的连接,远程服务是 API 的请求响应样式。RPC 调用是通过该方法进行的,该方法从使用相应参数填充的包(示例中的类型)中获取请求对象。然后返回响应对象(如上所示),并在结果可用时返回该响应对象。TelegramApi
doRpcCall
org.telegram.api.requests
TLRequestAuthCheckPhone
TLCheckedPhone
在异步调用的情况下,该方法立即返回,并在结果可用时执行回调方法:onResult
// Call service aynchronously
api.doRpcCall(checkPhone, new RpcCallbackEx<TLCheckedPhone>() {
public void onConfirmed() { }
public void onResult(TLCheckedPhone result) {
boolean invited = checkedPhone.getPhoneInvited();
boolean registered = checkedPhone.getPhoneRegistered();
// TODO process response further
}
public void onError(int errorCode, String message) { }
});