>
钥匙要点- Laravel收银员通过管理订阅账单,处理优惠券,交换订阅,取消宽限期和生成发票PDFS来简化基本付费会员网站的创建。
- > >要将Laravel收银员集成到现有的Laravel项目中,通过作曲家安装包裹,运行迁移以在用户表中添加必要的列,设置API键,然后将计费性状添加到模型中。 Laravel Abasier可以通过自动重试付款来处理失败的付款。如果付款继续失败,则将取消订阅。
- > Laravel Abasier目前仅支持Stripe和Braintree,但可以扩展到与其他付款网关合作,并以良好的了解Laravel和付款网关的API。
- 设置工作环境
- 我们需要创建一个布置项目才能开始,我们可以通过两种不同的方式来做:
我们可以克隆github repo到我们的项目文件夹。>
>假设您已经安装了作曲家(请查看安装指南以获取更多详细信息)。 我们运行作曲家create-project laravel/laravel laravel_membership-首发,这将在我们的laravel_membership文件夹中创建一个laravel样板项目。
- >现在,我们需要通过将“ Laravel/Cashier”:“ 〜1.0”添加到我们的Composer.json上的“要求”部分和运行作曲家更新以更新我们的依赖项,从而需要Laravel收银员包。 之后,我们需要告诉我们的应用程序加载收银员服务提供商类。我们可以通过在config/app.php文件上的提供商数组中添加“ LaravelCashierCashierServiceProvider”来做到这一点。 注意:您必须运行Composer dump-autoload才能更新Classmap软件包。
-
>使用迁移创建数据库
我们将使用两个表:
帖子表:
- int id- 字符串标题
- long_text内容- bool is_premium
>用户表:
- 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>注意:我们使用的是Billabretrait,并且特质需要5.4或更高的php。
>现在,我们必须设置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>接下来,我们将回调函数附加到我们的提交表单(请确保您的表单ID匹配事件处理程序上使用的表单),以防止双重提交我们禁用提交按钮。
stripe.card.createToken接受两个参数,第一个是JSON对象,具有一些必需和可选的值。
> exp_month:代表卡的到期月的两个数字编号。
- >
- exp_year:代表卡的到期年度的两个或四位数编号。
- >可选值:
>名称:持卡人名称。
- adversion_line1:帐单地址行1.
- adversion_line2:计费地址行2。
- adversion_city:帐单地址城市。
- address_state:计费地址状态。
- advelly_zip:按zip为字符串。
- > adversion_country:帐单地址国家。
- 您可以注意到,我们正在传递表单对象而不是JSON对象,您可以选择手动捕获值或在输入上使用数据 - 条纹HTML5属性,而条纹将使用一些帮助者方法自动为您获取这些值。例如:
- 第二个参数传递给stripe.card.createToken方法是一个回调函数,可以处理响应。
>如果失败,脱衣舞索Handler将尝试找到一个带有一类peays_errors的元素,以向用户显示一些描述性错误。
<span>php artisan cashier:table users</span>其他选项
>试验期:正如我们之前说的,当您创建一个新计划时,您可以选择指定试用期供用户测试您的产品,直到指定期限经过。
>优惠券:您可以通过仪表板菜单创建优惠券,您可以在其中指定固定金额或通过百分比,并提供其他一些有用的选项。
现在,让我们转到我们的IngeupController,看看我们将如何处理。
<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>
> withCoupon:我们之前说过,我们有可能创建折扣优惠券,在我们的示例中,我们可以这样做:
<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>取消:您可以使用此方法轻松取消订阅,但是您必须检查用户是否ongraceperiod才能确保不会立即阻止它们:
<span>return [ </span><span> 'stripe' => [ </span><span> 'secret' => 'Your key' </span><span> ] </span><span>];</span>trial:查看用户是否仍在试用期。
- >
- 取消:如果用户已取消其订阅。
> getlastfourcarddigits:获取用户卡的最后四位数。 - > > getSubscriptionEndDate:获取订阅结束日期。
- > getTrialendDate:获取试用日期。
- >发票:获取用户发票的列表。
- findInvoice:通过ID查找发票。
- > downloadinvoice:通过ID生成可下载的发票
- 结论
- 在本教程中,我们探讨了Laravel Abasier如何缓解计费流程并帮助您更轻松地管理客户。
- >我们当然没有在这里介绍所有内容,但是这是您挖掘源代码以探索您还能做什么的开始。如果您想查看此应用程序的一硝基托管演示,请参见此处。 >
关于Laravel Asasier会员资格的常见问题(常见问题解答) Laravel收银员如何处理订阅账单?
laravel收银员是一个有力的工具,可以简化管理订阅账单的过程。它为Stripe和Braintree的订阅计费服务提供了一种表现力,流利的界面。它处理您正在恐惧写作的几乎所有样板订阅计费代码。 Laravel收银员可以处理优惠券,交换订阅,订阅“数量”,取消宽限期,甚至生成发票PDFS。 'LL需要创建一个条纹帐户并通过作曲家安装收银员包。您还需要将可计费特征添加到您的模型定义中 - 此特征提供了各种方法,以允许您执行常见的计费任务,例如创建订阅,应用优惠券和更新卡信息。我将Laravel收银员集成到我现有的Laravel项目中?
>将Laravel Cashier整合到您现有的Laravel项目中很简单。首先,您需要通过作曲家安装软件包。然后,您需要通过运行迁移来准备数据库,该迁移将几列添加到您的用户表中。之后,您需要设置API键,并将可计费性状添加到模型中。最后,您可以使用可计费特征提供的各种方法来管理您的订阅。 Laravel Abasier处理失败的付款方式如何?Laravel Abasier具有内置功能来处理失败的付款。如果付款失败,收银员将自动重试付款。如果付款继续失败,则将取消订阅。但是,您也可以通过聆听相关事件并采取适当的措施来手动处理这些事件。
>我可以与其他付款网关一起使用Laravel Abasier吗?
>
>当前,Laravel Cashier仅支持Stripe和Stripe脑溪。但是,如果您愿意,您可以将收银员扩展到与其他付款网关合作。这将需要对Laravel和付款网关的API进行充分的了解。>我如何使用Laravel Abasier取消订阅?>您可以使用用户订阅上的CANCAL取消订阅来取消订阅。当取消订阅时,收银员将自动将订阅的结束日期设置为当前计费周期的结束。>我可以提供Laravel Abasier的试用期吗?支持试用期。您可以在创建订阅时设置试用期。在试用期结束之前,将不会向用户收费。
>如何使用Laravel收银员生成发票?您可以通过在发票实例上调用下载方法来访问发票的可下载PDF版本,它将将PDF写入磁盘或将其流式传输到浏览器中。
我可以使用Laravel Cashier将优惠券应用于订阅中吗?是的,Laravel Cashier支持将优惠券应用于订阅。您可以在创建新的订阅时使用withCoupon方法来执行此操作。
>我如何处理Laravel Abasier的订阅数量?
Laravel Aravel Cashier允许您处理订阅数量,这可以有用用于“每个座位”类型订阅。您可以在订阅实例上使用updateQuantity方法更新订阅的数量。>
以上是Laravel收银员的会员资格的详细内容。更多信息请关注PHP中文网其他相关文章!

要保护应用免受与会话相关的XSS攻击,需采取以下措施:1.设置HttpOnly和Secure标志保护会话cookie。2.对所有用户输入进行输出编码。3.实施内容安全策略(CSP)限制脚本来源。通过这些策略,可以有效防护会话相关的XSS攻击,确保用户数据安全。

优化PHP会话性能的方法包括:1.延迟会话启动,2.使用数据库存储会话,3.压缩会话数据,4.管理会话生命周期,5.实现会话共享。这些策略能显着提升应用在高并发环境下的效率。

thesession.gc_maxlifetimesettinginphpdeterminesthelifespanofsessiondata,setInSeconds.1)它'sconfiguredinphp.iniorviaini_set().2)abalanceIsiseededeedeedeedeedeedeedto to to avoidperformance andununununununexpectedLogOgouts.3)

在PHP中,可以使用session_name()函数配置会话名称。具体步骤如下:1.使用session_name()函数设置会话名称,例如session_name("my_session")。2.在设置会话名称后,调用session_start()启动会话。配置会话名称可以避免多应用间的会话数据冲突,并增强安全性,但需注意会话名称的唯一性、安全性、长度和设置时机。

会话ID应在登录时、敏感操作前和每30分钟定期重新生成。1.登录时重新生成会话ID可防会话固定攻击。2.敏感操作前重新生成提高安全性。3.定期重新生成降低长期利用风险,但需权衡用户体验。

在PHP中设置会话cookie参数可以通过session_set_cookie_params()函数实现。1)使用该函数设置参数,如过期时间、路径、域名、安全标志等;2)调用session_start()使参数生效;3)根据需求动态调整参数,如用户登录状态;4)注意设置secure和httponly标志以提升安全性。

在PHP中使用会话的主要目的是维护用户在不同页面之间的状态。1)会话通过session_start()函数启动,创建唯一会话ID并存储在用户cookie中。2)会话数据保存在服务器上,允许在不同请求间传递数据,如登录状态和购物车内容。

如何在子域名间共享会话?通过设置通用域名的会话cookie实现。1.在服务器端设置会话cookie的域为.example.com。2.选择合适的会话存储方式,如内存、数据库或分布式缓存。3.通过cookie传递会话ID,服务器根据ID检索和更新会话数据。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

记事本++7.3.1
好用且免费的代码编辑器

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。