Laravel6 使用腾讯云短信-添加短信模板

Laravel6 使用腾讯云短信

添加短信模板

新建 SmsTemplateRequestModel.php

touch app/Models/TencentCloud/SmsTemplateRequest.php # win 系统请将 "/" 更改成 "\", 或直接手动创建文件
/* app/Http/Requests/Api/SmsTemplateRequest.php */
<?php
namespace App\Http\Models\TencentCloud;

use TencentCloud\Sms\V20190711\Models\AddSmsTemplateRequest;

class SmsTemplateRequest
{
    /**
     * 添加短信模板 AddSmsTemplate
     *
     * @param String $templateContent 模板内容。
     * @param String $templateName 模板名称。
     * @param integer $smsType 短信类型,0表示普通短信, 1表示营销短信。
     * @param integer $international 是否国际/港澳台短信:
     *                               0:表示国内短信。
     *                               1:表示国际/港澳台短信。
     * @param String $remark 模板备注,例如申请原因,使用场景等。
     * @return void
     */
    public function addSmsTemplate(String $templateContent = '',String $templateName = '', int $smsType = 0, int $international = 0, String $remark = '')
    {
        // 实例化一个 sms 添加签名请求对象,每个接口都会对应一个request对象。
        $req = new AddSmsTemplateRequest();

        $req->TemplateContent = $templateContent;

        $req->TemplateName = $templateName;

        $req->SmsType = $smsType;

        $req->International = $international;

        $req->International = $international;

        $req->Remark = $remark;

        return $req;

    }
}

创建添加短信签名的验证类

php artisan make:request Api/SmsTemplateRequest
/* app/Http/Requests/Api/SmsTemplateRequest.php */
<?php
namespace App\Http\Requests\Api;

use Illuminate\Http\Request;

class SmsTemplateRequest extends FormRequest

{

    protected $addTemplateRules = [
        'templateContent' => 'required|String',
        'templateName' => 'required|integer',
        'smsType' => 'required|integer',
        'international' => 'required|integer',
        'remark' => 'required|String'
    ];

    /**

     * Get the validation rules that apply to the request.

     *

     * @return array

     */

    public function rules(Request $request)

    {

        switch ($request->method) {

            case 'POST':

                $rules = $this->addTemplateRules;

                break;

            default:

                $rules = $this->addTemplateRules;

                break;

        }

        return $rules;

    }

}

新建短信签名控制器

php artisan make:controller Api/SmsTemplateController
/* app/Http/Controllers/Api/SmsTemplateController.php */
<?php
namespace App\Http\Controllers\Api;

use App\Http\Requests\Api\SmsTemplateRequest;

use App\Http\Models\TencentCloud\SmsTemplateRequest as SmsTemplateRequestModel;

use TencentCloud\Common\Exception\TencentCloudSDKException;

class SmsTemplateController extends Controller

{

        public function addTemplate(SmsTemplateRequest $request,SmsTemplateRequestModel $SmsTemplateRequestModel)
    {
        try {
            $sms = app('tencentcloudSms');

            $req = $SmsTemplateRequestModel->addSmsTemplate($request->templateContent, $request->templateName, $request->smsType, $request->international, $request->remark);
            // 通过client对象调用DescribeInstances方法发起请求。注意请求方法名与请求对象是对应的
            // 返回的resp是一个DescribeInstancesResponse类的实例,与请求对象对应
            $resp = $sms->addSmsTemplate($req);

            list($AddTemplateStatus, $RequestId) = array_values(json_decode($resp->toJsonString(), true));

            if ($AddTemplateStatus['TemplateId']) {
                return response()->json([
                    'key' => $RequestId,
                    'code' => 0,
                    'message' => 'Ok',
                    'templateId' => $AddTemplateStatus['TemplateId']
                ])->setStatusCode(201);
            }

        } catch (TencentCloudSDKException $e) {
            return response()->json([
                'key' => $e->getRequestId(),
                'code' => $e->getErrorCode(),
                'message' => $e->getMessage()
            ])->setStatusCode(500);
        }
    }

}

新增路由

/* routes/api.php */
<?php

use Illuminate\Http\Request;

/*

|--------------------------------------------------------------------------

| API Routes

|--------------------------------------------------------------------------

|

| Here is where you can register API routes for your application. These

| routes are loaded by the RouteServiceProvider within a group which

| is assigned the "api" middleware group. Enjoy building your API!

|

*/

Route::prefix('v1')->namespace('Api')->name('api.v1.')->group(function () {

    // 添加短信模板
    Route::post('smsTemplate', 'SmsTemplateController@addTemplate')
        ->name('sms.template.add');

});

测试

通过 PostMan 测试一下:

Laravel6 使用腾讯云短信-添加短信模板

本作品采用《CC 协议》,转载必须注明作者和本文链接
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
讨论数量: 0
(= ̄ω ̄=)··· 暂无内容!

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!