


Der gesamte Prozess der Entwicklung einer APP-Schnittstelle mit PHP (1)
1. Lernpunkte:
Serverseite –> Aufrufschnittstelle –> Einführung: (PHP-Entwicklungs-APP-Schnittstelle)
PHP-objektorientierte Schnittstelle: abstrakte Klasse, Schnittstellendefinition==>interface.php
===>1 🎜>APP-Schnittstelle (Kommunikationsschnittstelle): Erhalten Sie Daten über die Schnittstelle und geben Sie die Daten in die APP ein
–> Fokus der APP-Entwickler: APP-Adresse (Schnittstellenadresse) anfordern + Daten zurückgeben
APP-(Kommunikations-)Schnittstellendefinition:
1. Schnittstellenadresse: http://app.com/api.php?format=xml
2. Schnittstellendatei: app .php Behandelt einige Geschäftslogiken
3. Schnittstellendaten
(empfohlenes Lernen:
PHP-Video-Tutorial)
Wie APP kommuniziert:C (接口地址:http://app.com/api.php?format=xml/json) S 客户端APP ------------------------------> 服务器 <----------------------------- 返回数据
rrree 2.json: Ein gut lesbares und schnell zu schreibendes Datenaustauschformat. Es kann für den Datenaustausch auf verschiedenen Plattformen verwendet werden, völlig unabhängig von der Sprache Textformat. Diese Eigenschaft macht JSON zu einer idealen Datenaustauschsprache.
Die Lesbarkeit von XML ist besser, die Datengenerierung von JSON (json_encode (array)) und die Übertragungsgeschwindigkeit sind besserWas die APP-Schnittstelle macht:
Daten abrufen: Daten aus der Datenbank oder dem Cache abrufen und die Daten dann über die Schnittstelle an den Client zurückgebenDaten senden: Daten über die Schnittstelle an den Server senden und dann verarbeiten es in die Datenbank über den Server oder eine andere Verarbeitung
6. JSON-Kapselungs-Kommunikationsschnittstelle
PHP generiert JSON-Daten: json_encode($arr); 🎜>Hinweis: Diese Funktion kann nur UTF-8-codierte Daten akzeptieren. Wenn Sie Daten in anderen Formaten übergeben, gibt die Funktion null zurückAnmerkungsformat für Kommunikationsdaten:
<?xml version="1.0" encoding="UTF-8"?> <item> <title>测试</title> <test id="1"> <description>测试oen</description> <address>深圳</address> </item>
code 状态码(200 400等) message 提示信息(邮箱格式不正确;数据返回成功等) data 返回相应的数据 —————————- -JSON code : 200 message :”数据返回成功” -data id :1 name : “测试”
某个server中: public function json($code,$message = '',$data = array()) { if (!is_numeric($code)){ return '错误'; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data ); echo json_encode($result); exit; }
public function jsonsAction() { $arr = array( 'id' => 1, 'name' => 'jiang' ); $k = wei()->zhwCategory()->json(200,'成功咯',$arr); return $k; }
7. PHP generiert XML-Daten:
7.1 PHP generiert XML-Daten 1. Assemble-String2. Verwenden Sie die Systemklasse: DomDocument
XMLWriter SimpleXML Bei Verwendung von DomDocument:{"code":200,"message":"\u6210\u529f\u54af","data":{"id":1,"name":"jiang"}}
<?php $dom = new DomDocument('1.0','utf-8'); $element = $dom->createElement('test','This id root element'); $dom->appendChild($element); echo $dom->saveXML(); ?>
Einfache Instanziierung mit zusammengesetzter Zeichenfolge:
<?xml version="1.0" encoding="utf-8"?> <test>This is the root element</test>
public static function xml() { header("Content-Type:text/html"); $xml = "<?xml version='1.0' encoding='UTF-8'?>\n"; $xml .= "<root>\n"; $xml .= "<code>200</code>\n"; $xml .= "<message>数据返回成功</message>\n"; $xml .= "<data>\n"; $xml .="<id>1</id>\n"; $xml .="<name>测试</name>\n"; $xml .="</data>\n"; $xml .="<root>"; echo $xml; }
7.2封装XML数据方法: 封装方法:xmlEncode($code,$message='',$data = array()); data数据分析: 1.array('index' => 'api'); 2.array(1,7.89); 具体: server模块下:
public function xmlEncode($code,$message = '',$data=array()) { if(!is_numeric($code)){ return "错误"; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data, ); header("Content-Type:text/xml"); $xml = "<?xml version='1.0' encoding='UTF-8'?>\n"; $xml .= "<root>\n"; $xml .=self::xmlToEncode($result); $xml .="</root>"; echo $xml; }
//对数据再处理
public function xmlToEncode($data){ $xml = $attr =""; foreach ($data as $key=>$value){ if(is_numeric($key)){ $attr = "id='{$key}'"; $key = "item"; } $xml .= "<{$key} {$attr}>"; //它们{$key} {$attr}之间要有一个小空格 $xml .=is_array($value) ? self::xmlToEncode($value):$value; $xml .="</{$key}>\n"; } return $xml; }
某个Controller:
8 .Umfassende Methode zur Kapselung von Kommunikationsdaten:
public function xmlsAction() { $arr = array( 'id' => 1, 'name' => 'jiang', 'type' =>array(4,5,6), 'test' =>array(1,45,67=>array(1,2,3)), ); $k = wei()->zhwCategory()->xmlEncode(200,'成功咯',$arr); return $k; }
Letzte Seite:
Server:
封装方法:show($code,$message,$data=array(),$type='json/xml')
<?php namespace Miaoxing\Zhw\Service; use miaoxing\plugin\BaseModel; class ZhwCategory extends BaseModel { const JSON = "json"; /** * 按x综合方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * @param string $type 数据类型 * return string */ public function show($code,$message='',$data=array(),$type = self::JSON) { if (!is_numeric($code)){ return "错误编码"; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data, ); if($type == 'json'){ self::json($code,$message,$data); exit; }elseif($type == 'array'){ var_dump($result); }elseif ($type == 'xml'){ self::xmlEncode($code,$message,$data); exit; }else{ //TODO } } /** * 按json方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * return string */ public function json($code,$message = '',$data = array()) { if (!is_numeric($code)){ return '错误'; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data ); echo json_encode($result); exit; } /** * 按xml方式输出通信数据 * @param integer $code 状态码 * @param string $message 提示信息 * @param array $data 数据 * return string */ public function xmlEncode($code,$message = '',$data=array()) { if(!is_numeric($code)){ return "错误"; } $result = array( 'code' => $code, 'message' => $message, 'data' => $data, ); header("Content-Type:text/xml"); $xml = "<?xml version='1.0' encoding='UTF-8'?>\n"; $xml .= "<root>\n"; $xml .=self::xmlToEncode($result); $xml .="</root>"; echo $xml; } //对数据再处理 public function xmlToEncode($data){ $xml = $attr =""; foreach ($data as $key=>$value){ if(is_numeric($key)){ $attr = "id='{$key}'"; $key = "item"; } $xml .= "<{$key} {$attr}>"; $xml .=is_array($value) ? self::xmlToEncode($value):$value; $xml .="</{$key}>\n"; } return $xml; } }
Das obige ist der detaillierte Inhalt vonDer gesamte Prozess der Entwicklung einer APP-Schnittstelle mit PHP (1). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

CakePHP ist ein Open-Source-MVC-Framework. Es erleichtert die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich. CakePHP verfügt über eine Reihe von Bibliotheken, um die Überlastung der häufigsten Aufgaben zu reduzieren.

Dieses Tutorial zeigt, wie XML -Dokumente mit PHP effizient verarbeitet werden. XML (Extensible Markup-Sprache) ist eine vielseitige textbasierte Markup-Sprache, die sowohl für die Lesbarkeit des Menschen als auch für die Analyse von Maschinen entwickelt wurde. Es wird üblicherweise für die Datenspeicherung ein verwendet und wird häufig verwendet
