>
钥匙要点我们运行作曲家create-project laravel/laravel laravel_membership-首发,这将在我们的laravel_membership文件夹中创建一个laravel样板项目。
我们将使用两个表:
帖子表:
- int id- 字符串标题
- long_text内容>用户表:
- int id
- varchar(60)密码
Laravel Artisan命令行工具使创建和管理迁移类都很容易。
>然后我们填充schema ::创建回调函数参数,并带有看起来像
要让Laravel Cashier知道我们的可计费表,我们需要为此创建一个特定的迁移。 Laravel Cashier为此目的具有内置命令。
<span>php artisan migrate:make create_posts_table --create="posts" </span><span> </span><span>php artisan migrate:make create_users_table --create="users"</span>
如果打开用户表,则在执行软件包迁移时会看到一堆字段。
- Stripe_active如果您有活动订阅。
- Stripe_ID用户ID上的Stripe Server上。
- Stripe_plan Stripe订阅计划。
- last_four信用卡最后四位数。
- 如果您指定试用期,则存储结束日期。
- subscription_ends_at subscription结束日期。
>现在,我们将使用一些虚拟数据播种数据库来开始。检查github上的最终结果。
处理付款可能会很痛苦,条纹可以帮助您,他们使用令牌代替卡号等。 。
>注意:检查您所在国家是否支持条纹,但您仍然可以使用它进行测试。
>要开始,我们需要先获取一个帐户。 Stripe没有订阅的月费,只有在获得付款时付款。
>现在,在获得帐户后,您需要为您的申请创建计划(每月,每年,银,金…)。
>
>每个领域都是自我解释的,因此让我们创建一个金色会员资格,价格为40美元,基本会员资格为10美元。他们每月都会被收费。
>我们已经在用户表中添加了必要的列,现在我们需要让Laravel Cashier知道我们将使用用户类用作计费类。
<span>Schema::create('posts', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('title'); </span><span> $table->longText('content'); </span><span> $table->boolean("is_premium"); </span><span> $table->timestamps(); </span><span>}); </span><span> </span><span>Schema::create('users', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('email', 100)->unique(); </span><span> $table->string('password', 60); </span><span> $table->timestamps(); </span><span>});</span>
>现在,我们必须设置Stripe API访问密钥,您可以从帐户>帐户设置> API键中获取并复制测试秘密密钥。
>
>通过使用BillabRetrait,我们可以访问用户:: setStripekey(键)方法,该方法可以在我们的代码中的任何地方称为,但是首选的方法是在您的配置目录下创建一个services.php文件,然后返回像这:
> GetStripeKey尝试加载钥匙时,它将寻找一个称为StripeKey的属性。如果找不到的话,它将自动加载您的服务文件。
<span>php artisan cashier:table users</span>
创建我们的页面
- 升级:从基本会员升级到黄金会员资格。
- 帖子:显示一个帖子页面。
为了加快流程,我们将使用Bootsnipp。您可以从github存储库中获取最终代码。
登录页面:
<span>php artisan migrate:make create_posts_table --create="posts" </span><span> </span><span>php artisan migrate:make create_users_table --create="users"</span>
>注册页面具有用于分配用户计划的订阅计划字段。
我们还有一个信用卡号,到期日期,CVC。
正如我们之前所说的,我们将永远不必处理任何付款或验证过程,我们将这些值传递给Stripe Server以照顾充电和验证过程。
>让我们看看前端代码的外观:
首先,我们包括JavaScript API文件,然后我们设置了我们从Stripe仪表板设置中获取的公共密钥。
<span>Schema::create('posts', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('title'); </span><span> $table->longText('content'); </span><span> $table->boolean("is_premium"); </span><span> $table->timestamps(); </span><span>}); </span><span> </span><span>Schema::create('users', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('email', 100)->unique(); </span><span> $table->string('password', 60); </span><span> $table->timestamps(); </span><span>});</span>
stripe.card.createToken接受两个参数,第一个是JSON对象,具有一些必需和可选的值。
> exp_month:代表卡的到期月的两个数字编号。
>名称:持卡人名称。
<span>php artisan cashier:table users</span>
>试验期:正如我们之前说的,当您创建一个新计划时,您可以选择指定试用期供用户测试您的产品,直到指定期限经过。
>优惠券:您可以通过仪表板菜单创建优惠券,您可以在其中指定固定金额或通过百分比,并提供其他一些有用的选项。
<span>php artisan migrate:make create_posts_table --create="posts" </span><span> </span><span>php artisan migrate:make create_users_table --create="users"</span>
我们将跳过验证过程以保持简单。
>创建新用户并保存它后,我们现在可以选择将用户订阅为新的会员计划。订阅方法接受已经注册的计划作为一个参数,可以是planInterface或字符串并返回条纹egateway。
创建方法接受令牌作为参数;我们通过名称exteToken的新隐藏输入值。
升级页面将提交给看起来像这样的升级器:
><span>Schema::create('posts', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('title'); </span><span> $table->longText('content'); </span><span> $table->boolean("is_premium"); </span><span> $table->timestamps(); </span><span>}); </span><span> </span><span>Schema::create('users', function(Blueprint $table) </span><span>{ </span><span> $table->increments('id'); </span><span> $table->string('email', 100)->unique(); </span><span> $table->string('password', 60); </span><span> $table->timestamps(); </span><span>});</span>
>我们检查用户是否首先登录,然后我们使用新计划创建一个新订阅,我们称之为交换方法,显然在一个真实的项目中,您将有一些费用调整和降级选项,但它应该有效同样的方式。
> PostController检查帖子IS_Premium是否,如果是的,我们测试用户是否是可以看到帖子的黄金成员,否则我们会返回一个简单的错误消息。
当然,在我们的routes.php文件中,我们需要添加一个验证过滤器,以防止未身份验证的用户访问页面。<span>php artisan cashier:table users</span>
<span>php artisan migrate</span>
<span>use Laravel\Cashier\BillableInterface; </span><span>use Laravel\Cashier\BillableTrait; </span><span> </span><span>class User extends Eloquent implements BillableInterface { </span><span> </span><span> use BillableTrait; </span><span> protected $dates = ['trial_ends_at', 'subscription_ends_at'];</span>
<span>return [ </span><span> 'stripe' => [ </span><span> 'secret' => 'Your key' </span><span> ] </span><span>];</span>
>我可以与其他付款网关一起使用Laravel Abasier吗?
我可以使用Laravel Cashier将优惠券应用于订阅中吗?是的,Laravel Cashier支持将优惠券应用于订阅。您可以在创建新的订阅时使用withCoupon方法来执行此操作。
以上是Laravel收银员的会员资格的详细内容。更多信息请关注PHP中文网其他相关文章!