环境简介
LNMP
1、Linux
2、Nginx
3、MySQL
4、PHP
APP接口
客户端与服务端数据的交换
HTTP通讯三要素
1、URL 地址
2、Method 方式
3、Params 内容
客户端传递参数
1、URl参数 GET
2、Request Body POST
(1)form-url
(2)form-data
(3)json
环境搭建
环境要求
PHP >= 7.0.0
全局安装composer
curl -sS https://getcomposer.org/installer | php mv composer.phar /usr/local/bin/composer
配置路径
cat ~/.bash_profile # composer export PATH=$PATH:$HOME/.composer/vendor/bin
安装 Laravel
composer global require "laravel/installer"
创建新应用
laravel new blog
本地开发服务器
php artisan serve
jquery.ajax
jQuery.ajax([settings])
type 类型:String
默认值: “GET”。请求方式 POST/GET/PUT/DELETE
url 类型:String
默认值: 当前页地址。发送请求的地址
contentType 类型:String
默认值: “application/x-www-form-urlencoded”。发送信息至服务器时内容编码类型。
data 类型:String
发送到服务器的数据
dataType 类型:String
预期服务器返回的数据类型。xml/html/script/json/jsonp/text
success 类型:Function
请求成功后的回调函数。
jsonp 类型:String
在一个 jsonp 请求中重写回调函数的名字
jsonpCallback 类型:String
为 jsonp 请求指定一个回调函数名
ajax发送各种请求
<html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script> </head> <body> <h1>hello</h1> <script> var data = { "name": "Tom", "age": 23 }; // 发送GET请求 $.ajax({ type: "GET", url: "/api/get", dataType: "json", data: data, success: function(data) { console.log(data); } }); // 发送POST请求 // Content-Type: application/x-www-form-urlencoded; charset=UTF-8 $.ajax({ type: "POST", url: "/api/post-form", dataType: "json", data: data, success: function(data) { console.log(data); } }); // 发送POST请求 不编码 // Content-Type: multipart/form-data; charset=UTF-8 var formData = new FormData(); formData.append("name", "Tom"); formData.append("age", "23"); $.ajax({ type: "POST", url: "/api/post-form-data", dataType: "json", contentType: false, processData: false, data: formData, success: function(data) { console.log(data); } }); // 发送json数据 // Content-Type: application/json; charset=UTF-8 $.ajax({ type: "POST", url: "/api/post-json", dataType: "json", contentType: 'application/json; charset=UTF-8', data: JSON.stringify(data), success: function(data) { console.log(data); } }); // 发送jsonp数据 $.ajax({ type: "GET", url: "/api/get-jsonp", dataType: "jsonp", data: data, success: function(data) { console.log(data); } }); </script> </body> </html>
PHP后端接收参数
routes/web.php
Route::get('/', function () { // return view('welcome'); return view('index'); });
routes/api.php
Route::get('/get', function () { $name = $_GET["name"]; $age = $_GET["age"]; echo json_encode([$name => $age]); }); Route::post('/post-form', function () { $name = $_POST["name"]; $age = $_POST["age"]; echo json_encode([$name => $age]); }); Route::post('/post-form-data', function () { $name = $_POST["name"]; $age = $_POST["age"]; echo json_encode([$name => $age]); }); Route::post('/post-json', function () { $ret = file_get_contents("php://input"); $data = json_decode($ret, true); $name = $data["name"]; $age = $data["age"]; echo json_encode([$name => $age]); }); Route::get('/get-jsonp', function () { $callback = $_GET["callback"]; $name = $_GET["name"]; $age = $_GET["age"]; echo $callback . "(" . json_encode([$name => $age]) . ")"; });
Laravel 接收GET或POST参数
Route::get('/getOrPost', function (Request $request) { $name = $request->input("name"); $age = $request->input("age"); echo json_encode([$name => $age]); });
XML和JSON
APP接口输出格式三要素
code 错误码
msg 错误码描述
data 接口数据
封装app接口数据格式
app/Http/Response/ResponseJson.php
<?php namespace App\Http\Response; /** * https://www.php.net/manual/zh/language.oop5.traits.php * traits 通过组合,代码复用 */ trait ResponseJson { /** * 接口数据错误时返回 */ public function jsonData($code, $message, $data=[]) { return $this->jsonResponse($code, $message, $data); } /** * 接口数据成功时返回 */ public function jsonSuccessData($data=[]) { return $this->jsonResponse(0, "success", $data); } /** * 封装接口数据格式 */ private function jsonResponse($code, $message, $data) { $content = [ "code" => $code, "message" => $message, "data" => $data ]; return json_encode($content); } }
app/Http/Controllers/Controller.php
<?php namespace App\Http\Controllers; use Illuminate\Routing\Controller as BaseController; use App\Http\Response\ResponseJson; class Controller extends BaseController { use ResponseJson; public function index() { return $this->jsonSuccessData(["name" => "Tom"]); } }
routes/api.php
Route::get('/index', "Controller@index");
访问测试
http://127.0.0.1:8000/api/index
{ code: 0, message: "success", data: { name: "Tom" } }
App接口鉴权
客户端需要带着凭证来调用APP接口
传统web cookie session鉴权
Json Web Token JWT
Header
Payload
Signature
Base64URL 算法:
Base64 有三个字符+、/和=,在 URL 里面有特殊含义,
所以要被替换掉:=被省略、+替换成-,/替换成_
问题:
Python binascii.Error: Incorrect padding
解决:
参数最后加上等于号"="(一个或者两个)
http://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html
composer require lcobucci/jwt
composer dump-autoload
错误码
错误码是用来描述当前接口处理的结果
错误码是前后端共同的一个约束
class ApiErrDesc { /** * 通用错误码 */ const SUCCESS = [0, "Success"]; const UNKNOWN_ERR = [1, "位置错误"]; /** * 其他错误码 */ const URL_ERR = [2, "url错误"]; } ApiErrDesc::SUCCESS[0], ApiErrDesc::SUCCESS[1]
异常处理
设置默认的异常处理程序,用于没有用 try/catch 块来捕获的异常
set_exception_handler
用户信息接口
1、数据库用户信息设计
2、开发用户信息接口
3、使用redis缓存加速用户信息接口
用户表
id、name、sex、email、password、create_time、update_time
unique email
密码hash和密码校验
$ php -a Interactive shell php > $ret = password_hash("123456", PASSWORD_DEFAULT); php > echo $ret; $2y$10$6AOQgUCZ7ukn.MAnilB0uuWxu4vrveWCMdPzFg4UyDVI5G7QR.fki php > echo password_verify("123456", $ret); 1
redis 缓存信息加快访问速度