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' => '893302826@qq.com', 'name' => 'LeoStupidWise'],
'encryption' => 'ssl',
'username' => '893302826@qq.com',
'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:是否将邮件发送记录到日志中。