前端ajax插件我没有使用vue-resource,说实话,用他遇到了坑,所以使用了axios.js,很好用,而且比vue-resource还小。
来看前端代码(省略vue逻辑部分):
axios.post('index.php/login',{
email:this.email,
pass:this.pass
}).then(function(res){
console.log(res)
}).then(function(){
console.log(321)
})this.email和this.pass即为用户填写的表单数据,点击登录即执行这个方法(验证数据格式没问题后)。
来看Laravel如何接收这两个值:
我们在app文件夹下建立一个GUser.php的Model文件,内容如下:
<?php
namespace App;
use Mongodb;
use DB;
class GUser extends Mongodb {
public static function login($email) {
$mongo = DB::connection('mongodb');
$res = $mongo->collection('user')->where('email',$email)->first();
return $res;
}
}再在app/Http/Controllers下建立一个GUserController.php文件,内容如下:
<?php
namespace AppHttpControllers;
use AppHttpControllersController;
use AppGUser;
use IlluminateHttpRequest;
class GUserController extends Controller{
protected function login(Request $request) {
$email = $request->input('email');
$pass = $request->input('pass');
$res = GUser::login($email);
return $res;
}
}当然啦,这里没有用到pass的值,我在这里省略了登录验证的逻辑。
然后在路由文件web.php里配置:
Route::any(‘/login','GUserController@login');
| 欢迎光临 一起源码网 (https://www.171739.xyz/) | Powered by Discuz! X3.3 |