基于laravel制作API接口

摘要:
访问API后应该得到什么。当我们开始设计API时,我们应该注意这8点。随后的开发计划就是基于此。

基于laravel制作API接口

关于API

API(Application Programming Interface,应用程序编程接口)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。
需要注意的是:API有它的具体用途,我们应该清楚它是干啥的。访问API的时候应该输入什么。访问过API过后应该得到什么。
在开始设计API时,我们应该注意这8点
后续的开发计划就围绕着这个进行了。
1.Restful设计原则
2.API的命名
3.API的安全性
4.API返回数据
5.图片的处理
6.返回的提示信息
7.在线API测试文档
8.在app启动时,调用一个初始化API获取必要的信息

用laravel开发API

就在我上愁着要不要从零开始学习的时候,找到了这个插件dingo/api那么现在就来安装吧!
首先一定是下载的没错
在新安装好的laravel的composer.json加入如下内容
然后打开cmd执行
composer update
在config/app.php中的providers里添加

AppProvidersOAuthServiceProvider::class,
DingoApiProviderLaravelServiceProvider::class,
LucaDegasperiOAuth2ServerStorageFluentStorageServiceProvider::class,
LucaDegasperiOAuth2ServerOAuth2ServerServiceProvider::class, 

  

在aliases里添加

'Authorizer' => LucaDegasperiOAuth2ServerFacadesAuthorizer::class,

  

修改app/Http/Kernel.php文件里的内容
protected $middleware = [LucaDegasperiOAuth2ServerMiddlewareOAuthExceptionHandlerMiddleware::class,
];
protected $routeMiddleware = [
 'oauth' => LucaDegasperiOAuth2ServerMiddlewareOAuthMiddleware::class,
 'oauth-user' => LucaDegasperiOAuth2ServerMiddlewareOAuthUserOwnerMiddleware::class,
 'oauth-client' => LucaDegasperiOAuth2ServerMiddlewareOAuthClientOwnerMiddleware::class,
 'check-authorization-params' => LucaDegasperiOAuth2ServerMiddlewareCheckAuthCodeRequestMiddleware::class,
 'csrf' => AppHttpMiddlewareVerifyCsrfToken::class,
];

  

然后执行

php artisan vendor:publish

php artisan migrate

  

在.env文件里添加这些配置

API_STANDARDS_TREE=x
API_SUBTYPE=rest
API_NAME=REST
API_PREFIX=api
API_VERSION=v1
API_CONDITIONAL_REQUEST=true
API_STRICT=false
API_DEBUG=true
API_DEFAULT_FORMAT=json

  

修改appconfigoauth2.php文件

'grant_types' => [
 'password' => [
 'class' => 'LeagueOAuth2ServerGrantPasswordGrant',
 'access_token_ttl' => 604800,
 'callback' => 'AppHttpControllersAuthPasswordGrantVerifier@verify',
 ],
],

  

新建一个服务提供者,在app/Providers下新建OAuthServiceProvider.php文件内容如下

namespace AppProviders;
  
use DingoApiAuthAuth;
use DingoApiAuthProviderOAuth2;
use IlluminateSupportServiceProvider;
  
class OAuthServiceProvider extends ServiceProvider
{
 public function boot()
 {
 $this->app[Auth::class]->extend('oauth', function ($app) {
 $provider = new OAuth2($app['oauth2-server.authorizer']->getChecker());
  
 $provider->setUserResolver(function ($id) {
 // Logic to return a user by their ID.
 });
  
 $provider->setClientResolver(function ($id) {
 // Logic to return a client by their ID.
 });
  
 return $provider;
 });
 }
  
 public function register()
 {
 //
 }
}

  

然后打开routes.php添加相关路由

//Get access_token
Route::post('oauth/access_token', function() {
 return Response::json(Authorizer::issueAccessToken());
});
  
//Create a test user, you don't need this if you already have.
Route::get('/register',function(){
 $user = new AppUser();
 $user->name="tester";
 $user->email="test@test.com";
 $user->password = IlluminateSupportFacadesHash::make("password");
 $user->save();
});
$api = app('DingoApiRoutingRouter');
  
//Show user info via restful service.
$api->version('v1', ['namespace' => 'AppHttpControllers'], function ($api) {
 $api->get('users', 'UsersController@index');
 $api->get('users/{id}', 'UsersController@show');
});
  
//Just a test with auth check.
$api->version('v1', ['middleware' => 'api.auth'] , function ($api) {
 $api->get('time', function () {
 return ['now' => microtime(), 'date' => date('Y-M-D',time())];
 });
});

  

分别创建BaseController.php和UsersController.php内容如下

//BaseController
namespace AppHttpControllers;
  
use DingoApiRoutingHelpers;
use IlluminateRoutingController;
  
class BaseController extends Controller
{
 use Helpers;
}
  
//UsersController
namespace AppHttpControllers;
  
use AppUser;
use AppHttpControllersController;
  
class UsersController extends BaseController
{
  
 public function index()
 {
 return User::all();
 }
  
 public function show($id)
 {
 $user = User::findOrFail($id);
 // 数组形式
 return $this->response->array($user->toArray());
 }

  

}

随后在app/Http/Controllers/Auth/下创建PasswordGrantVerifier.php内容如下

namespace AppHttpControllersAuth;
use IlluminateSupportFacadesAuth;
  
class PasswordGrantVerifier
{
 public function verify($username, $password)
 {
 $credentials = [
 'email' => $username,
 'password' => $password,
 ];
  
 if (Auth::once($credentials)) {
 return Auth::user()->id;
 }
  
 return false;
 }
}

  

打开数据库的oauth_client表新增一条client数据

INSERT INTO 'oauth_clients' ('id', 'secret', 'name', 'created_at', 'updated_at') VALUES ('1', '2', 'Main website', '2016–03–13 23:00:00', '0000–00–00 00:00:00');

  

随后的就是去愉快的测试了,这里要测试的API有

新增一个用户

http://localhost/register

读取所有用户信息

http://localhost/api/users

只返回用户id为4的信息

http://localhost/api/users/4

获取access_token

http://localhost/oauth/access_token

利用token值获得时间,token值正确才能返回正确值

http://localhost/api/time

打开PostMan

更多PHP内容请访问:

腾讯T3-T4标准精品PHP架构师教程目录大全,只要你看完保证薪资上升一个台阶(持续更新)

免责声明:文章转载自《基于laravel制作API接口》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Golang 对MongoDB的操作简单封装c#实现word,winWordControl 文档不允许复制、粘贴、隐藏工具栏、快捷保存下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

API网关实践-网易云轻舟微服务

微服务最佳实践中,我们需要通过统一的 API 网关进行服务能力的共享,API 网关为用户提供发布、管理、保护和监控 API的能力,帮助用户在自己的多个系统之间,或者内部系统与合作伙伴以及第三方的系统之间实现跨系统、跨协议的服务能力互通。 API网关应用场景 API网关有三种典型的应用场景: 内部业务集成:规范系统间API接口,快速完成企业内部系统的解耦及前...

WebApi返回Json格式字符串

WebApi返回json格式字符串, 在网上能找到好几种方法, 其中有三种普遍的方法, 但是感觉都不怎么好.  先贴一下, 网上给的常用方法吧. 方法一:(改配置法)  找到Global.asax文件,在Application_Start()方法中添加一句: protected void Application_Start() { Area...

postman-变量/环境/过滤等

之前虽然自己也有用postman来测试api,但都只是最简单输入url,发送,查看结果,大部分时候跟使用浏览器差不多,偶然在简书首页看到一篇 API开发神器-Postman , 深感还是得对自己使用的工具多琢磨一下,兴许你就发现了宝贝,大大加快开发测试速度了; 这里没有打算写全面的教程,只对我之前没了解的环境设置/变量使用以及对返回结果进行过滤等操作进行记...

Learning Scrapy笔记(六)- Scrapy处理JSON API和AJAX页面

摘要:介绍了使用Scrapy处理JSON API和AJAX页面的方法 有时候,你会发现你要爬取的页面并不存在HTML源码,譬如,在浏览器打开http://localhost:9312/static/,然后右击空白处,选择“查看网页源代码”,如下所示: 就会发现一片空白 留意到红线处指定了一个名为api.json的文件,于是打开浏览器的调试器中的Netw...

Bing API初体验 z

Bing正式发布没几天,除了功能和搜索结果外,作为开发者来说,我们关心的还有Bing API啥时候能出。周末浏览MSDN网站时,发现Bing Service已经上线了,链接是:http://msdn.microsoft.com/en-us/library/dd900818.aspx Bing提供的API很丰富,除了搜索外,还增加了广告Ad、图片、新闻、Ph...

API接口设计,需要注意这4点

原则上API接口设计一般出现在开发的详细设计中,但是随着诸多公司建立开放平台,产品经理也逐渐需要能理解API接口,尤其是做平台性的产品,还要学会定义接口。本文就关于产品经理在设计接口中需要定义什么、需要注意什么来展开陈述。 看到人人都是产品经理社区已经有关于API接口的相关介绍,因此本文就不做过多的关于API接口概念方面的介绍。 一、了解API的常识 在做...