我用Laravel-一些小技巧

1.控制器的灵活性(支持Ajax)

控制器要支持普通请求和AJAX请求,体现在参数的获取以及结果返回。
比如:

public function update(Request $request, $model_id = 0)
    {
        try {
// 参数获取
            if (!$model_id) {
                $model_id      =  $request->get("model_id");
                if (!$model_id) {
                    throw new \Exception("Invalid input", "4007");
                }
            }
//逻辑处理

//结果返回
            if ($request->ajax()) {
                return Response::json([
                    "errcode"     =>  "0000",
                    "errmsg"      =>  "Success"
                ]);
            } else {
                return redirect() -> to('/admin/user/wxtmpl/show'."/".$model->id) -> with("message", "更新消息成功");
            }
        } catch (\Exception $e) {
            info(__METHOD__."\n".$e->getTraceAsString());
            info($e->getCode()." | ".$e->getMessage());
            if ($request->ajax()) {
                return Response::json([
                    "errcode"   =>  $e->getCode()? $e->getCode(): "5000",
                    "errmsg"    =>  $e->getMessage(),
                ], JSON_UNESCAPED_UNICODE);
            } else {
                return redirect()->back()->withInput()->withErrors([
                    "fail"      =>  $e->getMessage(),
                ]);
            }
        }
    }

2.参数的合法性验证

在Laravel里面,提供了Validator门面来进行参数合法性验证 。

use Illuminate\Support\Facades\Validator;

//基本用法
$validator    =  Validator::make($request->all(), [
                "first"                =>  "required",
            ], [
                "first.required"       =>  "请填写first",
            ]);
            if ($validator->fails()) {
                $msg = $validator->messages()->first();
                throw new \Exception($msg);
            }

//自定义错误信息,在本例中,:attribute占位符将会被验证时实际的字段名替换
//你还可以在验证消息中使用其他占位符
            $messages          =  [
                "same"         =>  "The :attribute and :other must match",
                "size"         =>  "The :attribute must be exactly :size"
            ];

3.框架调用命令行

$exitCode = Artisan::call("shencom:get:tags:list:wx", ["acctid" => $acct_id])
即,使用Artisan门面的call函数。

4.RequestOnly

$data = $request->only([
    "name", "desc", "logo", "cate_id"
]);

可获得和下面语句相同的效果

$data = array(
    "name" => $request->get["name"],
    "desc" => $request->get["desc"],
    ....
);

5.Transaction事务

在查看文章的时候给文章的浏览量增加1。

//控制器中的方法
public function articleDetail($route, $id){
    try{
        \DB::transaction(function() use($id){
            Article::addViewCnt($id);
        });
    }
}

//模型中的方法
use SC\Forum\Models\Article as BaseArticle;
class Article extends BaseArticle{
    public static function addViewCnt( $article_id ){
        $result = Static::find($article_id);
        if($result){
            $result->read)cnt += 1;
            $result->save();
            return true;
        }else{
            return false;
        }
    }
}

6.在Laravel5.1中使用SMTP驱动实现邮件发送

参考
在config/mail.php里面做如下配置

return[
    'driver' => 'smtp',
    'host' => 'smtp.qq.com',
    'port' => 465,
    'from' => ['address' => '[email protected]', 'name' => 'LeoStupidWise'],
    'encryption' => 'ssl',
    'username' => '[email protected]',
    'password' => 'lxmixneovtxnbfgf',
    'sendmail' => '/usr/sbin/sendmial -bs',
    'pretend' => false,
]

HOST:邮箱所在主机,163对应smtp.163.com,QQ使用smtp.qq.com,其实还有更复杂的情况,QQ邮箱可以在邮箱设置里面去看到。
PORT:邮箱发送服务端口号,默认25,如果设置SMTP的SSL加密,该值为465。尝试时,25端口没有发送成功,只有设置SSL在465才能发送成功。
FROM:address表示发送邮箱,name表示发送邮箱使用的用户名。
ENCRYPTION:加密类型,null表示不加密,也可以设置为tls/ssl。
USERNAME:表示邮箱账号。
PASSWORD:表示登陆邮箱对应的授权码,QQ邮箱在设置中能获取。
PRETEND:是否将邮件发送记录到日志中。

你可能感兴趣的:(我用Laravel-一些小技巧)