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 = $_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

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

相关文章
|
6天前
|
开发框架 小程序 前端开发
圈子社交app前端+后端源码,uniapp社交兴趣圈子开发,框架php圈子小程序安装搭建
本文介绍了圈子社交APP的源码获取、分析与定制,PHP实现的圈子框架设计及代码编写,以及圈子小程序的安装搭建。涵盖环境配置、数据库设计、前后端开发与接口对接等内容,确保平台的安全性、性能和功能完整性。通过详细指导,帮助开发者快速搭建稳定可靠的圈子社交平台。
69 17
|
3天前
|
JSON 供应链 搜索推荐
淘宝APP分类API接口:开发、运用与收益全解析
淘宝APP作为国内领先的购物平台,拥有丰富的商品资源和庞大的用户群体。分类API接口是实现商品分类管理、查询及个性化推荐的关键工具。通过开发和使用该接口,商家可以构建分类树、进行商品查询与搜索、提供个性化推荐,从而提高销售额、增加商品曝光、提升用户体验并降低运营成本。此外,它还能帮助拓展业务范围,满足用户的多样化需求,推动电商业务的发展和创新。
18 5
|
2天前
|
移动开发 安全 搜索推荐
圈子社交系统APP,同城本地圈子论坛开发,让身边的人沟通更加紧密
圈子社交系统APP是一款基于社交网络的移动应用,用户可创建、加入和管理兴趣圈子。主要功能包括:动态分享与交流、实时聊天、会员体系与身份认证、活动策划等。该APP注重个性化定制、社交关系深化、隐私安全及跨平台互联,提供丰富的社交体验。
|
5天前
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
鸿蒙语言开发 几十套鸿蒙ArkTs app毕业设计及课程作业
17 1
|
14天前
|
JSON 缓存 前端开发
HarmonyOS NEXT 5.0鸿蒙开发一套影院APP(附带源码)
本项目基于HarmonyOS NEXT 5.0开发了一款影院应用程序,主要实现了电影和影院信息的展示功能。应用包括首页、电影列表、影院列表等模块。首页包含轮播图与正在热映及即将上映的电影切换显示;电影列表模块通过API获取电影数据并以网格形式展示,用户可以查看电影详情;影院列表则允许用户选择城市后查看对应影院信息,并支持城市选择弹窗。此外,项目中还集成了Axios用于网络请求,并进行了二次封装以简化接口调用流程,同时添加了请求和响应拦截器来处理通用逻辑。整体代码结构清晰,使用了组件化开发方式,便于维护和扩展。 该简介概括了提供的内容,但请注意实际开发中还需考虑UI优化、性能提升等方面的工作。
72 11
|
12天前
|
前端开发 数据库 UED
uniapp开发,前后端分离的陪玩系统优势,陪玩app功能特点,线上聊天线下陪玩,只要4800
前后端分离的陪玩系统将前端(用户界面)和后端(服务器逻辑)分开开发,前者负责页面渲染与用户交互,后者处理数据并提供接口。该架构提高开发效率、优化用户体验、增强可扩展性和稳定性,降低维护成本,提升安全性。玩家可发布陪玩需求,陪玩人员发布服务信息,支持在线聊天、预约及线下陪玩功能,满足多样化需求。[演示链接](https://www.51duoke.cn/games/?id=7)
|
13天前
|
移动开发 小程序 前端开发
使用php开发圈子系统特点,如何获取圈子系统源码,社交圈子运营以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP 小程序 H5
开发一个圈子系统(也称为社交网络或社群系统)可以是一个复杂但非常有趣的项目。以下是一些关键特点和步骤,帮助你理解如何开发、获取源码以及运营一个圈子系统。
85 3
|
18天前
|
供应链 搜索推荐 API
1688APP原数据API接口的开发、应用与收益(一篇文章全明白)
1688作为全球知名的B2B电商平台,通过开放的原数据API接口,为开发者提供了丰富的数据资源,涵盖商品信息、交易数据、店铺信息、物流信息和用户信息等。本文将深入探讨1688 APP原数据API接口的开发、应用及其带来的商业收益,包括提升流量、优化库存管理、增强用户体验等方面。
85 6
|
19天前
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
60 3
|
10天前
|
安全 算法 机器人
双重防护!红娘相亲app搭建开发,婚恋交友系统登录方式,密码+验证码的优势
在婚恋交友系统中,密码和验证码是两种重要的安全措施。密码用于验证用户身份,应设置为复杂组合以防止未经授权的访问;验证码则通过图形或字符识别,防止自动化攻击如暴力破解和注册机器人。两者同时开启可显著提高安全性,防止暴力破解和自动化注册,提升用户信任感。建议要求强密码、定期更新验证码样式,并在可疑登录时增加验证码复杂性。这样既能保障用户信息安全,又兼顾了用户体验。 ![交友11111.jpg](https://ucc.alicdn.com/pic/developer-ecology/hy2p6wcvgk4oe_c9eb8d6eb8144866b0cd1d96ffb0c907.jpg)