laravel 基础知识总结

1.请求类型
get , put , post , patch , delete 等
2.路由访问方式
get , post , any , match(['get',post])
3.路由传参
Route::get('user/{id}' ,function ($id){
});
Route::get('user/{name}/{id}',function($name,$id){
});
4.传递可选参数
Route::get('user/{name?}',function($name = value){
});
5.参数限制
Route::get('user/{name}',function(){})->where('name','[A-Za-z] + ');
Route::get('user/{id}/{name}',function(['id'=>'[0-9]+','name'=>'[a-z]+']));
6.模版中的写法
<h1><?php echo $title; ?></h1>
<p> {{$msg}}</p>
7.创建数据库
create database 库名 charset utf8
8.修改配置文件
在.env文件中进行修改
9.创建迁移文件
php artisan make:migration create_good_table --create=goods
执行这句命令 php artisan migrate
10.创建Model 文件控制表名,主键
php artisan make:model 表名
11.迁移文件操作
up()负责建表,加列,加索引
down()负责删表,减列,去索引
public function up(){
Schema::table('goods',function(Blueprint $table){
   添加
   $table->char('email',50);
});
Schema::table('goods',function ($table{
删除
$table->dropColumn('email');
}));
}
12.数据库迁移一操作
php artisan migrate:rollback 会退
php artisan migrate:reset 回退到初始状态
13.DB类操作数据库(Model)
insert 添加操作
DB::table()->insert(插入字段);(插入一维多维数组,返回true,false)
14.插入后返回主键值,获取主键值  insetrGetld();
$id = DB::table('goods')->insertGetId($rows);
15.update 修改操作
.典型的修改
DB::table('users')->where('id',1)->update(['age'=>19]);
相当于
update users set age = 19 where id =1;
在某值的基础上增长或者减少(默认1)
增长increment('健',步长);减少decrement();
16.delete删除操作
var_dump(DB::table('goods')->where('id','>',3)->delete());
where 有三个参数是,第二个参数当做运算符
17.select查找
DB::table('goods')->get();
DB::table('goods')->where('id','>',6)->get();
DB::table('goods')->select('id','email')->where()->get();
DB::table('goods')->where('id',6)->first();
18.表单提交要加一段_token();
<input type="hidden" name="_token" value="<?php echo csrf_token(); ?>">
19.不解析模版和防xss 攻击
在前段模版引擎中,用{{}}做表签边界
为防止blade 模版去解析前面加@
例如@{{$jang}}
['code'=>'<script>alert(1)</scriptt>']
&lt;script&gt;alert(1)&lt;/script&gt;
20.Model 放在/app目录下面,命名空间App
Model 继承Illuminate\Database\Eloquent\Model
引入new \App\Msg()
21.自动生成和实例化
php artisan make:model Msg
22.增加 
$msg->save();
23.查找
按键值查找
Msg::find($id);
按where 条件查找具体的那一条
Msg::where('id','>',3)->first();
查找多行all() 和 get()
24.delete 删除
Msg::where('id',$id)->delete();
25.复杂查询
asc   升序        desc 降序
orderBy('id','desc')  根据id排序
Msg::count();数数
Msg::avg('id');求平均值
Msg::min('id');最小值最大值
Msg::sum('id');求和
26.与Model有个约定
调整表名,主键值,屏蔽新增键值
27.控制器的生成
php artisan make:controller ArticleController --plain
--plain 去掉默认显示的
28.缓存位置
config/cache.php 默认用到的缓存驱动 file  其他缓存Memcached 和Redis
30.缓存调用
use Illuminate/Support/Facades/Cache
Cache::put('key','value',$minutes);
31.添加缓存
换存不存在添加缓存,缓存已经存在返回true,否则false
Cache::add('key','value',缓存时间);
持久话存储缓存
Cache::forever('key','val');
储存缓存放在storage/framework/
32.获取缓存
Cache::get('key','default');
如果有缓存输出缓存如果没有缓存返回default
pull 获取缓存后删除
33.删除缓存
Cache::forget('key');
清除所用缓存
Cache::flush();
判断缓存是否存在
Cache::has('key');
34.Request对象
请求方式(get/post)
请求参数($\post,$\FILES)
请求路径(域名后的部分)
请求Cookie等诸多信息
input 函数
35.利用Request对象做文件上传
Route::get('msg/fil','MsgController@fil');
Route::post('msg/ups','MsgController@ups');
控制器
public function fil(){
return view('msg.fil');
}
public function ups(){
$req->file()->move('上传文件地址',为文件起的名字);
}
判断文件上传是否成功
isvalid();即实例变量的值是否是个有效的对象句柄
hasFile();属性获取一个值,该值指示 FileUpload 控件是否包含要上载的文件。 在对要上载的文件执行操作之前,使用该属性来验证该文件是否存在
 
36.隐式控制器
Route::controller('article','ArticleController');
 
37.资源控制器
make:controller ArtisanController
Route::resource('article','ArticleController');
查看功能
php artisan route:list
 
38.laravel 缓存应用
静态缓存,查询缓存,数据缓存
静态缓存:缓存的整个页面;
动态缓存:存储数据库中的数据进行了缓存,既“通过动态缓存,不需要再读取数据库了,直接通过缓存文件来调取相应的数据”;
动态缓存:直接从缓存中读取,不经过数据查询;
 
39.缓存
存储缓存
Cache::put('key','value',$minutes);
 
40.laravel 中的路由与TP中的相比较
laravel 中的路由非常灵活,TP的路由是  模块/控制器/方法 TP 不能叫路由,只是URL与控制器的对应关系,或者叫URL分发;
41.设计区别laravel 连接网站的全过程,数据库+MVC+错误处理
 
42.laravel
array_collapse  函数将数组的每一个数组折合成单个数组:
str_limit('字符串',$num);  该函数接受一个字符串作为参数,以及最大字符数量作为第二个参数;
str_random();函数生成指定长度的随机字符串
e 函数对指定字符串进行实体转义,相当于htmlentities;
echo e('<html>foo<html>');
&lt;html&gt;foot;/html&gt
app_path()  返回当前项目的绝对路径 app 目录下的绝度路径
$path = app_path();
base_path() 返回项目的绝对路径
$path= base_path();
config_path() 返回项目的配置文件所在目录
public_path() 返回项目的公共文件所在目录(js,css,img ...)
attempt()  验证信息
url() 生成规则url
action() 配合路由器,生成规范 URl
bcrypt() 加密密码  (用户密码加密可以在创建数据库时进行加密)
config()  读取 配置值
csrf_field()  laravel 防止跨网站请求伪造攻击 用该命令用于验证授权用户和发送请求是否是同一个用户
<form method="post" actisan="/">
{{ csrf_field() }}
...........
</form>
request() 得到当前的request 对象
$req = request();
dd($req);
 
43.表单类型
primary (key)      主键值
string          字符串
enum          选择(‘男’,‘女’)
integer        整形
tinyint         整形(占一个字节)
int                整形(占四个字节)
auto_increment   属性自增
rememberToken()  laravel 中记录用户cookie
 
 
44.在模版中直接打印出错情况
{{print_r($errors)}}
 
45.路由分组
Route::group(
['prefix'=>'auth','namespace'=>'Auth'],
function(){
Route::get();
Route::post();
}
);
 
46.获取登入用户信息
$user = Auth::user();
$user = $request->user();
通过$user 实例化,可以拿到当前登入用户的信息
public function jiePost(Request $req){
$user = $req->user();
 
}
 
47.控制器模版展示view('she',['pro'=>$pro,'att'=>$att]);  已数组的形式进行展示
 
48.页面跳转
redirect('/prolist');
 
49.where 的用法
where('name','like','T%')
whereBetween('votes',[1,100]);    在某值的范围中
whereNotBetween();                      不在某值的范围中
insertGetId   自增ID
intval();                                             将变量转成整形
 
50.中间件
if else 判断的越来越多,会使代码更加难维护,系统间的的偶合性会增加,中间件解决了这个问题
生成中间件
php artisan make:middleware EmailMiddleware
生成的中间件位于
/app/Http/Middleware/EmailMiddleware
 
51.strtoupper()     函数把字符串转化为大写
52.分页功能
DB::table()->paginate(2);
return view('myze',['hks'=>$h]);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
posted @ 2017-09-03 14:42  辣姜  阅读(1002)  评论(0编辑  收藏  举报