好得很程序员自学网
  • 首页
  • 后端语言
    • C#
    • PHP
    • Python
    • java
    • Golang
    • ASP.NET
  • 前端开发
    • Angular
    • react框架
    • LayUi开发
    • javascript
    • HTML与HTML5
    • CSS与CSS3
    • jQuery
    • Bootstrap
    • NodeJS
    • Vue与小程序技术
    • Photoshop
  • 数据库技术
    • MSSQL
    • MYSQL
    • Redis
    • MongoDB
    • Oracle
    • PostgreSQL
    • Sqlite
    • 数据库基础
    • 数据库排错
  • CMS系统
    • HDHCMS
    • WordPress
    • Dedecms
    • PhpCms
    • 帝国CMS
    • ThinkPHP
    • Discuz
    • ZBlog
    • ECSHOP
  • 高手进阶
    • Android技术
    • 正则表达式
    • 数据结构与算法
  • 系统运维
    • Windows
    • apache
    • 服务器排错
    • 网站安全
    • nginx
    • linux系统
    • MacOS
  • 学习教程
    • 前端脚本教程
    • HTML与CSS 教程
    • 脚本语言教程
    • 数据库教程
    • 应用系统教程
  • 新技术
  • 编程导航
    • 区块链
    • IT资讯
    • 设计灵感
    • 建站资源
    • 开发团队
    • 程序社区
    • 图标图库
    • 图形动效
    • IDE环境
    • 在线工具
    • 调试测试
    • Node开发
    • 游戏框架
    • CSS库
    • Jquery插件
    • Js插件
    • Web框架
    • 移动端框架
    • 模块管理
    • 开发社区
    • 在线课堂
    • 框架类库
    • 项目托管
    • 云服务

当前位置:首页>后端语言>PHP
<tfoot draggable='sEl'></tfoot>

php怎么设置接口 php接口怎么写

很多站长朋友们都不太清楚php怎么设置接口,今天小编就来给大家整理php怎么设置接口,希望对各位有所帮助,具体内容如下:

本文目录一览: 1、 PHP创建接口 2、 php中如何调用接口以及编写接口代码详解 3、 php中怎么把数据库连接写成一个接口 4、 php如何开发API接口 PHP创建接口

.*****.com?token=yanzhengtype=jsondata=ourdata

格式可以这样设计,,token 是咱们首先在php中验证的内容,type是告诉用户的返回的同样是json数据 data 是要接受的数据

$token = $_GET['token']; php页面接受

$data = $_GET['data'] 得到数据后 再在php页面分析数据,最后入库 入库操作就不用说了吧

php中如何调用接口以及编写接口代码详解

可以用curl获取借楼的信息。

所谓接口,就是提供一个url,只要你满足它要求的参数,就能得到你要的数据。比如你拿到一个接口,带上所需的参数,复制到地址栏同样能得到。不过最好用程序得到。file_get_contents也可以用,不过有局限性。所以我建议用curl。给你一个函数,挺好用的。

function request($url,$https=true,$method='GET',$data=null){

$ch = curl_init();//初始化,得到资源

curl_setopt($ch, CURLOPT_URL,$url); //请求数据的路径

curl_setopt($ch, CURLOPT_HEADER,false);//是否输出头

curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); //不直接输出结果

//curl_setopt ($ch, CURLOPT_SAFE_UPLOAD, 0);//兼容php之后的版本

if($https){

curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); //是否验证主机

curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); //是否进行证书验证

}

if($method=='POST'){

curl_setopt($ch, CURLOPT_POST, true); //POST传输

curl_setopt($ch, CURLOPT_POSTFIELDS, $data); //传输数据

}

$content_json = curl_exec($ch);

if ($content_json === false) {

return "网络请求出错: " . curl_error($ch);

}

curl_close($ch);

return $content_json;

}

php中怎么把数据库连接写成一个接口

我自己封装的一个

<?php

class AppConfig{

public static $dbParam = array(

'dbHost' => 'localhost',

'dbUser' => 'root',

'dbPassword' =>'',

'dbName' => '数据库名',

'dbCharset' => 'utf8',

'dbPort' => 3306,

'dbPrefix' => 'test_',

'dbPconnect' => 0,

'dbDebug' => true,

);

}

class Model {

private $version = ''; //mysql版本

private $config = array(); //数据库配置数组

private $class; //当前类名

public $tablepre = 'ts_'; //表前缀

public $db = ''; //库名

public $table = ''; //表名

private static $link; //数据库链接句柄

private $data = array(); //中间数据容器

private $condition = ''; //查询条件

private $fields = array(); //字段信息

private $sql = array(); //sql集合,调试用

public $primaryKey = 'id'; //表主键

//构造函数初始化

public function __construct($dbParam = array()) {

$this->config = (is_array($dbParam) !empty($dbParam)) ? $dbParam : AppConfig::$dbParam;

$this->connect();

$this->init();

}

//链接数据库

private function connect() {

if($this->config['dbPconnect']) {

self::$link = @mysql_pconnect($this->config['dbHost'], $this->config['dbUser'], $this->config['dbPassword']);

}else{

self::$link = @mysql_connect($this->config['dbHost'], $this->config['dbUser'], $this->config['dbPassword'], true);

}

mysql_errno(self::$link) != 0 $this->errdie('Could not connect Mysql: ');

$this->db= !empty($this->db) ? $this->db : $this->config['dbName'];

$serverinfo = $this->version();

if ($serverinfo > '4.1' $this->config['dbCharset']) {

mysql_query("SET character_set_connection=".$this->config['dbCharset'].",character_set_results=".$this->config['dbCharset'].",character_set_client=binary", self::$link);

}

if ($serverinfo > '5.0') {

mysql_query("SET sql_mode=''", self::$link);

}

@mysql_select_db($this->db, self::$link) or $this->errdie('Cannot use database');

return self::$link;

}

//表基本信息初始化

protected function init() {

$this->class = get_class($this);

$this->table = !empty($this->table) ? $this->table : strtolower($this->class);

$this->table = $this->tablepre . $this->table;

return $this;

}

//设置属性值

public function __set($name, $value) {

//exit($value);

$this->data['fields'][$name] = $value;

}

//获取属性值

public function __get($name) {

if(isset($this->data['fields'][$name])) {

return($this->data['fields'][$name]);

}else {

return NULL;

}

}

//字段信息处理

private function implodefields($data) {

if (!is_array($data)) {

$data = array();

}

$this->fields = !empty($this->data['fields']) ? array_merge($this->data['fields'], $data) : $data;

foreach($this->fields as $key => $value) {

$fieldsNameValueStr[] = "`$key`='$value'";

$fieldsNameStr[] = "`$key`";

$fieldsValueStr[] = "'$value'";

}

return array($fieldsNameValueStr, $fieldsNameStr, $fieldsValueStr);

}

//条件判断组装

private function condition($where = NULL) {

if (is_numeric($where)) {

$where = "WHERE `{$this->primaryKey}`='{$where}' LIMIT 1";

}elseif (is_array($where)){

$where = "WHERE `{$this->primaryKey}` in (".implode(',',$where).")";

}elseif(!empty($this->data['condition'])){

//'预留WHERE', 'order', 'group', 'limit' …………等条件关键词处理接口

$where = $where ? "WHERE {$where}" : "WHERE 1";

isset($this->data['condition']['where']) $where .= ' AND '.$this->data['condition']['where'];

isset($this->data['condition']['group']) $where .= ' GROUP BY '.$this->data['condition']['group'];

isset($this->data['condition']['order']) $where .= ' ORDER BY '.$this->data['condition']['order'];

isset($this->data['condition']['limit']) $where .= ' LIMIT '.$this->data['condition']['limit'];

}else{

$where = "WHERE {$where}";

}

$this->condition = $where;

return $this;

}

//插入数据

public function insert($data = array(), $replace = false) {

$fields = $this->implodefields($data);

$insert = $replace ? 'REPLACE' : 'INSERT';

$sql = "{$insert} INTO `{$this->db}`.`{$this->table}` (".implode(', ',$fields[1]).") values (".implode(', ',$fields[2]).")";

$this->query($sql);

return $this->getInsertId();

}

//更新数据

public function update($data = array() ,$where = '') {

$numargs = func_num_args();

if ($numargs == 1) {

$where = $data;

$data = array();

}

$fields = $this->implodefields($data);

$this->condition($where);

$sql = "UPDATE `{$this->db}`.`{$this->table}` SET ".implode(', ',$fields[0])." {$this->condition}";

$this->query($sql);

return $this->getAffectedRows();

}

//删除数据

public function delete($where = NULL) {

if(!is_array($where) strtolower(substr(trim($where), 0, 6)) == 'delete'){

$sql = $where;

}else{

$this->condition($where);

$sql = "DELETE FROM `{$this->db}`.`{$this->table}` {$this->condition}";

}

$this->query($sql);

return $this->getAffectedRows();

}

//查询数据

public function select($where = NULL, $fields = '*') {

if(!is_array($where) strtolower(substr(trim($where), 0, 6)) == 'select'){

$sql = $where;

}else{

$this->condition($where);

$sql = "SELECT {$fields} FROM `{$this->db}`.`{$this->table}` {$this->condition}";

}

return $this->fetch($this->query($sql));

}

//查询一条数据

public function getOne($where, $fields = '*') {

$data = $this->select($where, $fields = '*');

if($data) {

return $data[0];

}

return array();

}

//查询多条数据

public function getAll($where, $fields = '*') {

$data = $this->select($where, $fields = '*');

return $data;

}

//结果数量

public function getCount($where = '', $fields = '*') {

$this->condition($where);

$sql = "SELECT count({$fields}) as count FROM `{$this->db}`.`{$this->table}` {$this->condition}";

$data = $this->query($sql);

if($data){

return @mysql_result($data,0);

}

return 0;

}

//执行sql语句(flag为0返回mysql_query查询后的结果,为1返回lastid,其他返回影响行数,默认为2返回影响行数)

public function query($sql, $flag = '0', $type = '') {

if ($this->config['dbDebug']) {

$startime = $this->microtime_float();

}

//查询

if ($type == 'UNBUFFERED' function_exists('mysql_unbuffered_query')) {

$result = @mysql_unbuffered_query($sql, self::$link);

} else {

//exit($sql);

$result = @mysql_query($sql, self::$link);

}

//重试

if (in_array(mysql_errno(self::$link), array(2006,2013)) empty($result) $this->config['dbPconnect']==0 !defined('RETRY')) {

define('RETRY',true); @mysql_close(self::$link); sleep(2);

$this->connect();

$result = $this->query($sql);

}

if ($result === false) {

$this->errdie($sql);

}

if ($this->config['dbDebug']) {

$endtime = $this->microtime_float();

$this->sql[] = array($sql,$endtime-$startime);

}

//清空操作数据

$this->data = array();

return $flag == '0' ? $result : ($flag == '1' ? $this->getInsertId() : $this->getAffectedRows());

}

//返回结果$onlyone为true返回一条否则返回所有,$type有MYSQL_ASSOC,MYSQL_NUM,MYSQL_BOTH

public function fetch($result, $onlyone = false, $type = MYSQL_ASSOC) {

if($result){

if ($onlyone) {

$row = @mysql_fetch_array($result, $type);

return $row;

}else{

$rowsRs = array();

while($row=@mysql_fetch_array($result, $type)) {

$rowsRs[] = $row;

}

return $rowsRs;

}

}

return array();

}

//可以运行SELECT,SHOW,EXPLAIN 或 DESCRIBE 等返回一个资源标识符的语句得到返回结果数组

public function show($sql, $onlyone = false) {

return $this->fetch($this->query($sql), $onlyone);

}

// 使用call函数处理同类型函数

private function __call($name, $arguments) {

$callArr = array('on', 'where', 'order', 'between', 'group', 'limit');

if (in_array($name, $callArr)) {

$this->data['condition'][$name] = $arguments[0];

}else{

$this->errdie("function error: function {$name} is not in ($this->class) class exist");

}

return $this;

}

//返回最后一次插入ID

public function getInsertId() {

return @mysql_insert_id(self::$link);

}

//返回受影响行数

public function getAffectedRows() {

return @mysql_affected_rows(self::$link);

}

//获取错误信息

private function error() {

return ((self::$link) ? @mysql_error(self::$link) : @mysql_error());

}

//获取错误信息ID

private function errno() {

return ((self::$link) ? @mysql_errno(self::$link) : @mysql_errno());

}

//获取版本信息

function version() {

if(empty($this->version)) {

$this->version = mysql_get_server_info(self::$link);

}

return $this->version;

}

//打印错误信息

private function errdie($sql = '') {

if ($this->config['dbDebug']) {

die('</BR><B>MySQL ERROR</B></BR>

SQL:'.$sql.'</BR>

ERRNO:'.$this->errno().'</BR>

ERROR:'.$this->error().'</BR>');

}

die('DB ERROR!!!');

}

//获取时间微妙数

private function microtime_float()

{

list($usec, $sec) = explode(" ", microtime());

return ((float)$usec + (float)$sec);

}

//析构函数

public function __destruct() {

echo '<hr>';

$this->config['dbDebug'] print_r($this->sql);

//unset($this->result);

//unset($this->condition);

//unset($this->data);

}

}

class user extends Model {

//public $db = 'qsf_mvc';

//public $table = 'user';

public $primaryKey = 'uid';

}

$userObj = new user();

//---------------------------------------插入数据方法一-----------------------------------------

//模拟ActiveRecord模式 插入数据

$userObj->username = 'hoho';

$userObj->passwd = '1478522';

$userObj->email = 'qsf.z11@163.com';

$userObj->sex = 1;

$userObj->desc = '清洁工';

$insetId = $userObj->insert();

if ($insetId > 0) {

echo "插入ID为:{$insetId}<BR>";

}

//---------------------------------------插入数据方法二-----------------------------------------

//直接数组做参数插入数据

$userArr = array(

'username' => 'hoho',

'passwd' => '1478522',

'email' => 'qsf.z2121ia@163.com',

'sex' => '1',

'desc' => '厨师',

);

$insetId = $userObj->insert($userArr);

if ($insetId > 0) {

echo "插入ID为:{$insetId}<BR>";

}

//---------------------------------------更新数据方法一----------------------------------------

$userObj->username = 'h111oho';

$userObj->passwd = '1478511122';

$userObj->email = 'qsf111ia@163.com';

$userObj->sex = 1;

$userObj->desc = '清洁工';

$affectedRows1 = $userObj->update(89);

if ($affectedRows1 > 0) {

echo "影响行数为:{$affectedRows1}<BR>";

}

//---------------------------------------更新数据方法二----------------------------------------

//更新记录(传递参数的方式和insert操作一样)

$userArr = array(

'username' => 'hohoho',

'passwd' => '1474rr4448522',

'email' => 'qsf.rrza@165.com',

'sex' => '0',

'desc' => '厨师qq',

);

$affectedRows = $userObj->update($userArr, $insetId);

if ($affectedRows > 0) {

echo "影响行数为:{$affectedRows}<BR>";

}

//----------------------------------------查询数据----------------------------------------------

$userRs0 = $userObj->select(8); //单个主键值

//print_r($userRs0);

$userRs1 = $userObj->select(array(1,5,8)); //多个主键值的数组

//print_r($userRs1);

$userRs2 = $userObj->select('select count(*) as count from user where uid > 20'); //直接完整sql语句

//print_r($userRs2);

$userRs3 = $userObj->select("`uid` > 0"); //where条件

//print_r($userRs3);

$userRs4 = $userObj->getOne("`uid` > 0"); //获取单条记录

//print_r($userRs4);

$usersRs5 = $userObj->getAll("`uid` > 0"); ////获取所有记录

//print_r($usersRs5);

$usersRs6 = $userObj->limit('0,10')->where('uid > 100')->order('uid DESC')->group('username')->select();

//print_r($usersRs6);

//----------------------------------------删除数据-----------------------------------------------

//删除操作传递参数的方式和select操作一样

$userObj->delete(60); //单个主键值

$userObj->delete(array(1,5,8)); //多个主键值的数组

$userObj->delete('delete from user where uid > 100'); //直接完整sql语句

$userObj->delete("`uid` > 100"); //where条件

$userObj->limit('5')->where('uid > 80')->delete();

//----------------------------------------特殊查询-----------------------------------------------

$userShowRs = $userObj->show('show create table user', true); //获取特殊查询的结果,第二个参数代表返回一条结果还是所有的结果

php如何开发API接口

比如一个自定义函数:function test(){echo ‘hello world’;}就可以叫做 api。api 既可以是单个的函数,也可以是封装在类里的方法,当然它们也是程序代码。开发一个 api 的流程可以很简单,也可以很复杂,视具体的编程任务而决定,并没有特定的规则。比如,你需要为自己建立一个常用的函数库,命名为 my.lib.php然后把你自己编写的自定义函数,全部写在这个文件里面,那么,你就拥有了自己的api。开发的时候,只需要引入 my.lib.php,你就可以调用自己的 api 了。这是一个比较简单的例子。稍微复杂一点的,你可以把函数封装在类里面,方便继承和重用,还可以根据函数名称做一些程序设计,这个一句话说不清楚,给一个简单的例子吧:class mylib{function showmy(){echo ‘这是我的一个类方法’;}}调用的时候,先要实例化类,然后再调用方法。再复杂一点的就是使用类接口,区别就是接口里面定义的只是方法原型,而你需要通过具体的类来实现接口中的函数,具体请参考 php 手册

关于php怎么设置接口的介绍到此就结束了,不知道本篇文章是否对您有帮助呢?如果你还想了解更多此类信息,记得收藏关注本站,我们会不定期更新哦。

查看更多关于php怎么设置接口 php接口怎么写的详细内容...

声明:本文来自网络,不代表【好得很程序员自学网】立场,转载请注明出处:http://haodehen.cn/did196104
更新时间:2023-04-26   阅读:29次

上一篇: php构造请求头 php设置请求头

下一篇:php网站如何修改 php网站用什么软件修改

相关资讯

最新资料更新

  • 1.php使用嵌套for php解析嵌套json
  • 2.文章加载更多php php加载html
  • 3.php相除保留到分 php除法保留小数
  • 4.mes开源框架PHP mes开源框架 python
  • 5.iconv函数php iconv函数参数
  • 6.php怎么登录会员 怎么用php完成登录页面
  • 7.phpjson提交 phppost提交
  • 8.phpping测速 测试php性能工具
  • 9.php添加curl支持 php curl formdata
  • 10.php操作redis存值 php redis数据类型
  • 11.php下载控件 php下载器
  • 12.php类属性分类 php数据类型
  • 13.php瀑布流响应 html 瀑布流
  • 14.php构造方法重写 php 构造方法
  • 15.php网站设计素材 php网站制作
  • 16.搭建分站源码php 建立分站怎么建
  • 17.php求100的质数 php求出1100的素数
  • 18.php网页老是跳转 php 网页跳转
  • 19.php例子下载 php资料下载
  • 20.网页识别不了php文件 php网页无法显示

CopyRight:2016-2025好得很程序员自学网 备案ICP:湘ICP备09009000号-16 http://haodehen.cn
本站资讯不构成任何建议,仅限于个人分享,参考须谨慎!
本网站对有关资料所引致的错误、不确或遗漏,概不负任何法律责任。
本网站刊载的所有内容(包括但不仅限文字、图片、LOGO、音频、视频、软件、程序等)版权归原作者所有。任何单位或个人认为本网站中的内容可能涉嫌侵犯其知识产权或存在不实内容时,请及时通知本站,予以删除。

网站内容来源于网络分享,如有侵权发邮箱到:kenbest@126.com,收到邮件我们会即时下线处理。
网站框架支持:HDHCMS   51LA统计 百度统计
Copyright © 2018-2025 「好得很程序员自学网」
[ SiteMap ]