我已经为订阅服务实施了应用内结算。一切都很好,但我正处于需要确保安全的地步。我遇到的各种建议建议通过Plus API使用登录用户的帐户ID。但是,如果用户没有使用他们的Gmail帐户登录,我将如何获得此信息?我的想法是生成一个根据用户帐户ID和sku组合创建的令牌。然后检查我的服务器以验证购买。有没有办法获取用户的帐户ID?我希望只需一次购买即可在多个设备上使用该应用。如果用户没有使用任何社交API登录,是否有办法在多个设备上验证用户?
答案 0 :(得分:3)
经过多次试验,错误和研究,我找到了解决方案。所以对于可能有相同需求/问题的其他人来说:
首先,将其添加到build.gradle文件中:
compile' com.google.android.gms:play-services-auth:10.2.0'
然后,在需要获取用户帐户ID的活动中添加以下内容:
public class MainActivity extends AppCompatActivity{
private static final int REQUEST_CODE_EMAIL = 1;
TextView email, mAcctId;
Button getID;
String accountName;
String TAG = "test";
private static final int REQ_SIGN_IN_REQUIRED = 55664;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
email = (TextView) findViewById(R.id.email);
mAcctId = (TextView)findViewById(R.id.accountID);
//Shows a popup allowing user to select email if more than one exists
try {
Intent intent = AccountPicker.newChooseAccountIntent(null, null,
new String[] { GoogleAuthUtil.GOOGLE_ACCOUNT_TYPE }, false, null, null, null, null);
startActivityForResult(intent, REQUEST_CODE_EMAIL);
} catch (ActivityNotFoundException e) {
// TODO
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == REQUEST_CODE_EMAIL && resultCode == RESULT_OK) {
accountName = data.getStringExtra(AccountManager.KEY_ACCOUNT_NAME);
email.setText(accountName);
//Call async task to get accountID for selected email
new RetrieveAccountID().execute(accountName);
}
}
private class RetrieveAccountID extends AsyncTask<String, Void, String> {
@Override
protected String doInBackground(String... params) {
String accountName = params[0];
String token = null;
try {
token = GoogleAuthUtil.getAccountId(getApplicationContext(), accountName);
} catch (IOException e) {
Log.e(TAG, e.getMessage());
} catch (UserRecoverableAuthException e) {
startActivityForResult(e.getIntent(), REQ_SIGN_IN_REQUIRED);
} catch (GoogleAuthException e) {
Log.e(TAG, e.getMessage());
}
return token;
}
@Override
protected void onPostExecute(String s) {
super.onPostExecute(s);
((TextView) findViewById(R.id.accountID)).setText("AccountID: " + s);
}
}
}
运行该功能可以在一个TextView中为用户选择电子邮件,在另一个TextView中为该电子邮件提供accountID。现在可以使用哪个为用户电子邮件独有的应用创建令牌/密钥。当用户在其他设备上使用应用时,这也可用于验证令牌/密钥。