PHP:APP接口开发

简介: PHP:APP接口开发

环境简介

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

http://localhost:8000

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 &#61; $_GET["name"];
$age &#61; $_GET["age"];
echo json_encode([$name &#61;&gt; $age]);
});

Route::post('/post-form', function () {
$name &#61; $_POST["name"];
$age &#61; $_POST["age"];
echo json_encode([$name &#61;&gt; $age]);
});

Route::post('/post-form-data', function () {
$name &#61; $_POST["name"];
$age &#61; $_POST["age"];
echo json_encode([$name &#61;&gt; $age]);
});

Route::post('/post-json', function () {
$ret = file_get_contents("php://input");
$data &#61; json_decode($ret, true);

$name &#61; $data["name"];
$age &#61; $data["age"];
echo json_encode([$name &#61;&gt; $age]);

});

Route::get('/get-jsonp', function () {
$callback &#61; $_GET["callback"];

$name &#61; $_GET["name"];
$age &#61; $_GET["age"];

echo $callback . &#34;(&#34; . json_encode([$name => $age]) . ")";
});

Laravel 接收GET或POST参数

Route::get('/getOrPost', function (Request $request) {
$name &#61; $request->input("name");
$age &#61; $request->input("age");

echo json_encode([$name &#61;&gt; $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-&gt;jsonResponse($code, $message, $data);
}

/**
* 接口数据成功时返回
*/
public function jsonSuccessData($data=[])
{
return $this-&gt;jsonResponse(0, &#34;success&#34;, $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

https://jwt.io/


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 缓存信息加快访问速度

            </div>
目录
相关文章
|
JavaScript 前端开发
Vue antdv 定制主题配置(高低版本配置问题)
Vue antdv 定制主题配置(高低版本配置问题)
612 0
|
9月前
|
数据采集 存储 机器学习/深度学习
最新AI大模型数据集解决方案:分享两种AI高质量代码数据集生产方案
本文分享了两种构建高质量AI代码数据集的解决方案。第一种是传统方式,结合动态住宅代理与手动处理,通过分页读取和数据清洗生成结构化数据;第二种是利用Web Scraper API工具,实现自定义配置、自动化抓取及云端存储。两种方法各具优势,适合不同需求和技术水平的团队。同时,文章还提供了专属优惠福利,助力提升数据采集效率,为AI大模型训练提供支持。
332 5
最新AI大模型数据集解决方案:分享两种AI高质量代码数据集生产方案
|
弹性计算 运维 Linux
运维工程师必备的摸鱼神器:阿里云智能助手OS Copilot
OS Copilot 概述与体验评测摘要 阿里云的OS Copilot是一款基于大模型的智能操作系统助手,作为高级运维工程师,体验者发现它在系统诊断和性能优化上尤其有用,简化了如重置ECS密码和安全组配置等任务,提升了工作效率。 OS Copilot的易用性和安全性得到肯定,操作手册详细且交互性强,减少了用户在不同页面间切换的需要。在辅助编程方面,它能帮助非专业开发者编写和理解代码,对运维工作中的开发技能补充有很大帮助。与GitHub Copilot等产品相比,OS Copilot的独特之处在于结合了Linux操作的支持。
593 3
运维工程师必备的摸鱼神器:阿里云智能助手OS Copilot
|
存储 Ubuntu Linux
VMware虚拟机配置Linux Ubuntu操作系统
本文介绍基于VMware Workstation Pro虚拟机软件,配置Linux Ubuntu操作系统环境的方法~
844 1
VMware虚拟机配置Linux Ubuntu操作系统
|
SQL 数据库
SQL中CASE WHEN THEN ELSE END的用法详解
SQL中CASE WHEN THEN ELSE END的用法详解
3644 2
|
开发框架 缓存 前端开发
ASP.NET Core MVC 从入门到精通系列文章(完)
ASP.NET Core MVC 从入门到精通系列文章(完)
928 0
|
Java 关系型数据库 MySQL
JSP出租房管理系统myeclipse开发mysql数据库BS模式java编程网页结构
JSP 出租房管理系统是一套完善的web设计系统,对理解JSP java编程开发语言有帮助,系统具有完整的源代码和数据库,开发环境为TOMCAT7.0,Myeclipse8.5开发,数据库为Mysql5.0,使用java语言开发,系统主要采用B/S模式开发。
152 0
|
前端开发 数据可视化 数据管理
零起点入门系列教程⑤:用宜搭简单布局一个首页
【零起点入门系列教程】将会带给大家从业务视角出发由浅入深地学习用宜搭实现应用搭建。即便是没有任何代码基础的新手只要跟着系列课程,从0开始慢慢修炼,也能找到成功搭建应用的乐趣。今天第五讲,如何用宜搭简单布局一个首页。
3626 0
零起点入门系列教程⑤:用宜搭简单布局一个首页
|
机器学习/深度学习 弹性计算 数据可视化
阿里云GPU云服务器,gn6v、gn6i、gn5i购买和选择教程
GPU 云服务器(GPU Cloud Computing,GPU)是提供 GPU 算力的弹性计算服务,提供GPU加速计算能力,实现GPU计算资源的即开即用和弹性伸缩,具有超强的计算能力,服务于深度学习、科学计算、图形可视化、视频处理多种应用场景。阿里云作为亚洲第一的云服务提供商,随时为您提供触手可得的算力,有效缓解计算压力,提升您的业务效率,助您提高企业竞争力。
|
Web App开发 JavaScript 前端开发
Chrome浏览器Tab开太多了,怎么办
# 背景 在日常工作中,我想大家应该都有一个烦扰,Chrome浏览器的Tab开得太多了,找到需要使用的Tab太难了,过多的Tab也会导致系统性能下降。为此,我上chrome应用商店寻找可以解决这个问题的拓展程序,尝试了很多拓展程序,没有找到一个满意的拓展程序。 为什么不自己动手做一个自己想要的拓展程序呢,于是我就开始了chrome拓展程序开发之旅。首先,我将介绍我开发的拓展程序SortYo

热门文章

最新文章