Java 如何实施';服务器端';使用SQLite将代码条带化到Android应用程序中
我能够使用条纹创建一个标记。但现在我想创建一个客户,并最终创建一个收费,他们将展示如何在您的服务器上进行收费。但我正在使用SQLite作为我的数据库,因为这个应用程序只会被少数人使用,并且只会被我加载到一个平板电脑上。所以我的问题是,我可以在我的应用程序中创建一个客户,而不必将整个服务器端后端构建到我的应用程序中吗 下面是我创建代币的代码,现在我想用这个代币创建一个客户:(忽略应用程序的混乱,对不起,最后的应用程序会更干净,只是试着看看我是否能让它工作)Java 如何实施';服务器端';使用SQLite将代码条带化到Android应用程序中,java,android,sqlite,stripe-payments,Java,Android,Sqlite,Stripe Payments,我能够使用条纹创建一个标记。但现在我想创建一个客户,并最终创建一个收费,他们将展示如何在您的服务器上进行收费。但我正在使用SQLite作为我的数据库,因为这个应用程序只会被少数人使用,并且只会被我加载到一个平板电脑上。所以我的问题是,我可以在我的应用程序中创建一个客户,而不必将整个服务器端后端构建到我的应用程序中吗 下面是我创建代币的代码,现在我想用这个代币创建一个客户:(忽略应用程序的混乱,对不起,最后的应用程序会更干净,只是试着看看我是否能让它工作) 不幸的是,在Android应用程序中不可
不幸的是,在Android应用程序中不可能执行这些操作,因为这些调用需要您的API密钥。你永远不应该在你的Android应用程序中拥有这个秘密API密钥,否则攻击者可能会得到它,然后代表你进行收费、退款或转账 这里您需要做的是首先创建一个卡令牌(您已经创建了),然后将其发送到您的服务器,在那里您将使用您的密钥创建费用或客户。在Android应用程序中,这一切都不会发生 您可以参考另一个问题:检查一些关于如何向服务器发送令牌的Android代码 在服务器端,您需要检索令牌,然后使用它创建或
package com.zeuspwr.zeuspower;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.ImageButton;
import android.widget.Spinner;
import android.widget.Toast;
import com.stripe.android.*;
import com.stripe.android.model.Card;
import com.stripe.android.model.Token;
import com.stripe.android.Stripe;
import java.util.HashMap;
import java.util.Map;
public class newUser extends AppCompatActivity {
EditText fNameh;
EditText lNameh;
EditText emailh;
EditText phoneNumh;
EditText pinh;
EditText cardNumberh;
EditText cardCVCh;
Spinner cardExpMonthh;
Spinner cardExpYearh;
String fname;
String lname;
String email;
String phonenum;
String pin;
String cardNumber;
String cardCVC;
Integer cardExpMonth;
Integer cardExpYear;
String stripetok;
Card cardNew;
String cardExpMonthStr;
String cardExpYearStr;
private static final String PUBLISHABLE_KEY = "pk_test_iUVdhdvJuurqSxIlXpzq32LS";
UserDBHelper newUserr;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_new_user);
newUserr = new UserDBHelper(newUser.this);
fNameh = (EditText) findViewById(R.id.fNameNew);
lNameh = (EditText) findViewById(R.id.lNameNew);
emailh = (EditText) findViewById(R.id.emailNew);
phoneNumh = (EditText) findViewById(R.id.phoneNew);
pinh = (EditText) findViewById(R.id.pinNew);
cardNumberh = (EditText) findViewById(R.id.cardNumNew);
cardCVCh = (EditText) findViewById(R.id.cvcNew);
cardExpMonthh = (Spinner) findViewById(R.id.monthNew);
cardExpYearh = (Spinner) findViewById(R.id.yearNew);
ImageButton createNewUser = (ImageButton) findViewById(R.id.createNew);
createNewUser.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
fname = fNameh.getText().toString();
lname = lNameh.getText().toString();
email = emailh.getText().toString();
phonenum = phoneNumh.getText().toString();
pin = pinh.getText().toString();
cardNumber = cardNumberh.getText().toString();
cardCVC = cardCVCh.getText().toString();
cardExpMonthStr = cardExpMonthh.getSelectedItem().toString();
cardExpYearStr = cardExpYearh.getSelectedItem().toString();
cardExpMonth = Integer.valueOf(cardExpMonthStr);
cardExpYear = Integer.valueOf(cardExpYearStr);
cardNew = new Card(
cardNumber,
cardExpMonth,
cardExpYear,
cardCVC
);
if(cardNew.validateCard() & cardNew.validateCVC()) {
final Stripe stripe = new Stripe();
stripe.createToken(cardNew, PUBLISHABLE_KEY, new TokenCallback() {
public void onSuccess(Token token) {
// TODO: Send Token information to your backend to initiate a charge
Toast.makeText(
getApplicationContext(),
"Token created: " + token.getId(),
Toast.LENGTH_LONG).show();
}
public void onError(Exception error) {
Log.d("Stripe", error.getLocalizedMessage());
}
});
}
else{
Toast.makeText(
getApplicationContext(),
"Token not made!",
Toast.LENGTH_LONG).show();
}
/*Intent retPage = new Intent(BorroworReturn.this, returno.class);
startActivity(retPage);*/
}
});