❶ php中ratchet類庫怎麼使用
Ratchet 可使用簡單的 HTML、JS 和 CSS 來製作一個 iPhone 應用的原型。
❷ PHP資料庫操作之基於Mysqli的資料庫操作類庫
此類庫簡單、易用,便於你自己修改和對功能的改善,能解決大部分
PHP
項目中執行的
SQL
操作。
初步工作
首先,請大家下載這個類庫
M.class.php 再下載一個
Mysqli
連接資料庫的類庫
MysqliDb.class.php(打包下載地址)
新建一個
includes
的文件夾,將下載下來的兩個
class
文件,放進去。
然後,請你在項目下創建一個
test.php
文件。註:UTF-8
文件格式
請先根據你機器的情況,填充以下代碼,用於連接資料庫:
復制代碼
代碼如下:
header('Content-Type:text/html;Charset=utf-8');
define('ROOT_PATH',
dirname(__FILE__));
define('DB_HOST',
'localhost');
//資料庫伺服器地址
define('DB_USER',
'root');
//資料庫用戶名
define('DB_PWD',
'×××');//資料庫密碼
define('DB_NAME',
'×××');
//資料庫名稱
define('DB_PORT',
'3306');
//資料庫埠
function
__autoload($className)
{
require_once
ROOT_PATH
.
'/includes/'.
ucfirst($className)
.'.class.php';
//自動載入
class
文件
}
好了,上面的這些操作都是初步工作,下面正式進入類庫的講解。
類庫講解
首先,我們得實例化
M.class.php,實例化很簡單:
復制代碼
代碼如下:
$m
=
new
M();
//這步操作代表
M.class.php
中的所有功能都封裝在了變數
$m
中
註:
1、M類庫中的方法參數說明,請到
M.class.php
文件中看詳細的注釋,這里不再進行敘述。建議在學習的時候,對照著看下文件中的參數即注釋。
2、講解代碼中用到的資料庫結構為:
復制代碼
代碼如下:
CREATE
TABLE
`user`
(
`id`
int(8)
unsigned
NOT
NULL
auto_increment,
`name`
varchar(50)
default
NULL,
`email`
varchar(100)
default
NULL,
`age`
smallint(3)
default
NULL,
`class_id`
int(8)
default
NULL,
`commit_time`
int(10)
default
NULL,
PRIMARY
KEY
(`id`),
KEY
`name`
(`name`)
)
ENGINE=MyISAM
DEFAULT
CHARSET=utf8
復制代碼
代碼如下:
CREATE
TABLE
`class`
(
`class_id`
int(8)
NOT
NULL
auto_increment,
`class_name`
varchar(100)
default
NULL,
PRIMARY
KEY
(`class_id`)
)
ENGINE=InnoDB
DEFAULT
CHARSET=utf8
並添加一條測試數據。
3、M類庫中,大部分方法都分兩中類型,即:SQL方法;拼接方法,具體在實例中可以看出
4、以下稱述中的
M
為
M.class.php
文件
方法1、Insert()
添加數據
Insert
方法的全部使用案例如下:
復制代碼
代碼如下:
$m->Insert("user",
null,
array('焦焦',
'[email protected]',
'23',
time()));
//
拼接方法:往`user`表中添加一條數據,返回值為資料庫影響的行數
$m->Insert("user",
null,
array('焦焦',
'[email protected]',
'23',
time()),
true);
//
功能同上,返回
last_insert_id(插入的增長id)
$m->Insert("INSERT
INTO
`user`
(`name`,
`email`,
`age`,
`commit_time`)
VALUES
('張小花',
'[email protected]',
'22',
'".time()."')");
//SQL方法,返回值為資料庫影響的行數
$m->Insert("INSERT
INTO
`user`
(`name`,
`email`,
`age`,
`commit_time`)
VALUES
('張小花',
'[email protected]',
'22',
'".time()."')",
true);
//
同上,返回
last_insert_id
註:Insert
方法中的第二個參數若為null,可自動獲得插入表除
auto_increment
欄位之外的所有欄位,詳情請看M源文件;若要返回值為最後插入的
ID,那麼請設置
Insert
方法的最後一個參數為
true(默認是false);
方法2、Update()
修改數據
update
方法的全部使用案例如下:
復制代碼
代碼如下:
$m->Update("user",
array('name'=>'李茹茹',
'age'=>24),
"id=1");
//拼接方法,修改id為1的數據的名稱為「李茹茹」;年齡為「24」,其方法的返回值為受影響的行數
$m->Update("UPDATE
`user`
SET
`name`='李茹茹',
`age`=24
WHERE
id
=
1");
//SQL
用法,功能同上
方法3、Del()
刪除數據
Del
方法的全部使用案例如下:
復制代碼
代碼如下:
$m->Del('user',
'id=3');
//拼接方法:刪除`user`表中
id
為3的數據,返回受影響的行數
$m->Del("DELETE
FROM
`user`
WHERE
id=4");
//SQL方法:刪除`user`表中
id
為4的數據,返回受影響的行數
$m->Del("DELETE
FROM
`user`
WHERE
id
in
(10,
11,
12)");
//SQL方法:刪除多條數據,刪除`user`表中
id
為
10、11、12
的數據,返回受影響的行數
方法4、Total()
獲取記錄數,返回值都為int
Del
方法的全部使用案例如下:
復制代碼
代碼如下:
$m->Total('user');
//拼接方法:返回
`user`表中的記錄數,無條件
$m->Total('user',
'id>1');
//拼接方法:返回
`user`表中
id
大於1的記錄數,有條件
$m->Total("SELECT
COUNT(*)
AS
total
FROM
`user`");
//SQL方法,註:使用SQL方法,語句中必須使用
"AS
total",否則會報錯
方法5、IsExists()
檢查數據是否存在,返回值為boolean
復制代碼
代碼如下:
$m->IsExists('user',
"`name`='焦焦'");
//拼接方法:返回`user`表中是否存在`name`為「焦焦」的數據,返回true,若不存在,返回false
方法6、InsertId()
獲取表下一個添加的自動增長id,注意,這里不進行添加操作,只是獲取下一個增長id
復制代碼
代碼如下:
echo
$m->InsertId('user');
//獲取`user`
表下一個添加的自動增長id
方法7、GetRow()
返回單條數據,返回值為一維數組
GetRow
方法的全部使用案例如下:
復制代碼
代碼如下:
$data
=
$m->GetRow("SELECT
`name`,email
FROM
`user`
WHERE
id=1");
//SQL方法,返回一維數組,例如:Array
(
[name]
=>
焦焦
[email]
=>
[email protected]
)
$data
=
$m->GetRow("SELECT
u.`name`,
u.email,
c.class_name
FROM
`user`
u,
`class`
c
WHERE
u.class_id=c.class_id
AND
u.id=1");
//SQL方法,多表查詢
$data
=
$m->GetRow('user',
'`name`,email',
"id=1");
//拼接方法
$data
=
$m->GetRow('user
as
u,`class`
c',
'u.`name`,u.email,c.class_name',
"u.id=1
AND
u.class_id=c.class_id");
//拼接方法,多表查詢
$data
=
$m->GetRow("SELECT
`name`,email
FROM
`user`");
//如果沒有指定條件應該是顯示全部信息,但是在此方法中將默認顯示第一條(不推薦這么使用!!!)
$data
是查詢出來的一維數組。
方法8、GetOne()
返回單個數據
GetOne
方法的全部使用案例如下:
復制代碼
代碼如下:
$name
=
$m->GetOne("SELECT
`name`
FROM
`user`
WHERE
id=1");
//SQL方法,返回一個字元串,例如:焦焦
$name
=
$m->GetOne("user",
"name",
"id=1");
//拼接方法,返回一個字元串,例如:焦焦
方法9、FetchAll()
返回所有記錄
復制代碼
代碼如下:
$data
=
$m->FetchAll("user");
//返回`user`表中的所有記錄,以二維數組的形式
$data
=
$m->FetchAll("SELECT
*
FROM
`user`");
//SQL
方法,功能和返回值同上
$data
=
$m->FetchAll("user",
"name,email",
"id>1",
'id
DESC',
'2');
//返回兩條id>1的數據,只顯示name,email,並且以id
為倒序排序。註:請注意該方法的最後一個參數也可以為'0,2',目的是為分頁准備的,如果第一頁為'0,2'的話,那麼第二頁就是'2,2'
//該方法也支持聯表查詢和多表查詢,下面以聯表查詢為例
$data
=
$m->FetchAll("`user`
as
u
LEFT
JOIN
`class`
as
c
ON
u.class_id=c.class_id",
"u.`name`,u.email,
c.class_name",
"u.id=1");
//注意:該拼接方法中,ON
添加的位置
註:對於該
FetchAll
方法,後續我會寫一篇使用該方法進行完美分頁的文章!!請關注。
方法10、MultiQuery()
執行多條SQL語句
復制代碼
代碼如下:
$sql
=
"INSERT
INTO
user
(`name`,email,
age,
class_id,
commit_time)
VALUES
('賈花花',
'[email protected]',
'22',
'1',
'".time()."')";
//添加一個名叫「賈花花」的學生信息
$sql
.=
";DELETE
FROM
`user`
WHERE
`name`='焦焦'";
//刪除一條名叫「焦焦」的學生信息
//解釋:$sql
是多條
SQL
以英文;(分號)拼接起來的
$data
=
$m->MultiQuery($sql);
//返回為true,代表執行成功;為false,代表執行失敗
類庫講解完畢
到此該類庫的全部功能就講解完畢,希望你能多看看M文件,了解其內部運行的機制。M
文件不會存在執行緩慢情況,請大家放心使用。
如果在使用過程中出現
SQL
拼接錯誤,類庫會報出友善的錯誤提示。
有問題請留言,歡迎大家的批評和建議,加油!學習好運。
❸ php interface類庫怎麼使用
問這個問題,應該懂得interface怎麼用的。那隱畢我就說說interface的深刻意義吧 1、這些都是思想信鏈層面的東西,現在大多數開發語言都有這些特性,在學習語言的同時,要注重思想的養成,包括面對對象開發、MVC、interface、繼承、重寫等等這滑攜孫些都是要弄...
❹ 實用的15款開源PHP類庫
PHP庫給開發者提供了一個標准介面 它幫助開發者在PHP里充分利用面向對象編程 這些庫為特定類型的內置功能提供了一個標準的API 允許類可以與PHP引擎進行無縫的交互 此外 開發者使用這些類庫還可以簡化工作流程 提供工作效率
下面就一起來看看這些非常實用且免費的類庫吧 希望它們能助你一臂之力
Requests
Requests是一個用PHP編寫的HTTP庫 遵循ISC開源協議 託管在GitHub上 Requests取代了Python HTTP/ 以外的一切工作———讓你與Web服務可以無縫的結合
Requests提供了一致的API 並且使用cURL或fsockopen(具體取決於可用性) 它還簡化了發送請求 接受HEAD GET POST PUT DELETE或PATCH並且添加標頭 表單數據和多個部分組成的文件 其次 該庫還適用於國際域名 身份驗證 自動壓縮gzip壓縮響應等 綜上所述可以看出 Requests是一個非常好用且可以友好託管HTTP請求的標簽
Munee
Munee是一個集圖片尺寸調整 CSS JS合並/壓縮 緩存等功能於一身的PHP庫 可以在伺服器端和客戶端緩存資源 它集成了PHP圖片操作庫Imagine來實現圖片尺寸調整和剪切 之後進行緩存
Munee可以自動編譯LESS SCSS和CoffeeScript 並且可以把CSS+JS文件合並成一個單一的請求 此外 還可以對這些CSS JS文件進行精縮 讓其擁有更好的性能表現 該庫還可以輕易地與任何代碼集成
Ratchet
Ratchet是一個PHP庫 WebSockets工具包 開發者可以使用它在客戶端和伺服器端之間構建實時 雙向的App應用 並且可以快速簡單地構建事件驅動應用程序(而不是傳統的HTTP 請求/響應應用程序)
Swift Mailer
Swift Mailer是一個功能豐富的PHP郵件庫 不依賴於PHP自帶的mail() 函數 因為該函數在發送多個郵件時佔用的系統資源很高 Swift直接與SMTP伺服器通訊 具有非常高的發送速度和效率
Unirest
Unirest是一個輕量級的HTTP開發庫 可用於PHP Ruby Python Java Objective C等開發語言 支持GET POST PUT UPDATE DELETE操作 它的調用方法與返回結果對所有開發語言來說 都是相同的
Detector
Detector是一個開源的PHP類庫 用於檢測用戶的瀏覽器環境 它可以獲得瀏覽器的使用情況和瀏覽器的HTML CSS 功能 並分析是否是移動 平板電腦 桌面或網頁爬蟲和其他項 如 顏色深度 視頻尺寸 Cookie等 該庫對每個瀏覽器用戶都使用單一的用戶代理字元串來自動適應新瀏覽器 版本和設備
PHP Thumb
PHP Thumb是一個PHP類 用來生成圖片的縮略圖 只需數行代碼即可 支持多種圖片來源 包括文件系統或者資料庫 支持大多數圖片格式 並可對圖片進行旋轉 剪切 加水印等等 可自定義縮略圖的質量 提供內建的緩存以降低伺服器的負載
Zebra Image
Zebra Image是一個開源的輕量級圖像處理庫 並且是一款面向對象庫 只需PHP GD 擴展 並支持縮放 裁剪 旋轉和翻轉操作 它可以用於 jpg gif png等格式
Hybrid Auth
HybridAuth是一個開源PHP類庫 用於通過微博/社交網站和ID來提供驗證功能實現同步登錄網站功能 它能夠很方便的與現有網站相集成 只要引用一個文件並添加幾行代碼就能夠實現登錄 一旦驗證 HybridAuth會提供連接用戶的標准化相關資料 此外 除了驗證功能 這個類庫能夠讓我們與用戶連接的social API客戶端相交互
Gantt Charts
Gantti是一個開源的PHP類 幫助用戶即時生成Gantt圖表 使用Gantti創建圖表無需使用JavaScript 是純HTML CSS 圖表默認輸出非常漂亮 但用戶可以自定義樣式進行輸出(SASS樣式表)
Mobile Detect
Mobile Detect是一個PHP類 通過User Agent檢測各種手機設備 並結合HTTP Header來檢測移動設備環境 該類庫最強大的地方是 它有一個非常完整的庫 可以檢測出所用的設備類型(包括操作類型 以及手機品牌等都能檢測)和瀏覽器的詳細信息
ImageWorkshop
顧名思義 ImageWorkshop是一個管理和操作圖片的PHP類庫 這個類擁有類似圖片編輯軟體的邏輯 基於層的概念 可以疊加很多層或層組(每一層不同的操縱選項) 它還支持許多功能 比如水印 裁剪 移動 縮放 旋轉 疊加等
JqmPhp
JqmPhp是一個PHP開源類庫 旨在簡化jQuery與PHP來進行移動開發 用於生成使用jQuery Mobile框架所需要的HTML文件 該類庫的文件是獨立的 所以你可以根據需要來選擇使用
PHP Image Cache
Image Cache是一個輕量級的PHP類 可以在用戶瀏覽器里壓縮 移動 緩存圖片 這個類提供一些簡單的設置如 目錄 根路徑URL等 然後針對每一張圖片調用壓縮功能
Imagine
Imagine是一個面向對象的PHP類庫 用於圖片操作 這個類庫能夠處理一些經常用到的操作如 縮放 裁剪 應用過濾等 其Color類庫可用於對任意特定的顏色生成RGB值 並且還提供一些方法來繪制圖形如 圓弧 橢圓 線 片等
lishixin/Article/program/PHP/201404/30630
❺ thinkphp5 自動載入的類 怎麼使用
ThinkPHP的類庫主要包括公共類庫和應用類庫,都是基於命名空間進行定義和擴展的。只要按照規范定義,都可以實現自動載入。
類庫存放位置:
Think目錄:系統核心類庫
Org目錄:第三方公共類庫
這些目錄下面的類庫都可以自動載入,只要把相應的類庫放入目錄中,然後添加或者修改命名空間定義。你可以在Org/Util/目錄下面添加一個Image.class.php
文件,然後添加命名空間如下:
namespace Org\Util;
class Image {
}
這樣,畝枝胡就可以用下面的方式直接實例化Image類了:$image = new \Org\Util\Image;
公共迅攔類庫除了在系統的Library目錄之外,還可以自定義其他的命名空間,只需要注冊一個新的命名空間,在應用或者模塊配置文件中添加下面的設置參數:
'AUTOLOAD_NAMESPACE' => array(
'Lib' => APP_PATH.'Lib',
)
如果類庫沒有採用命名空間的話,需要使用import方法先載入類庫文件,然後再進行實例化搭燃,例如:定義了一個Counter類(位於Com/Sina/Util/Counter.class.php):
import('Com.Sina.Util.Couter');
$object = new \Counter();
❻ 如何在PHP擴展中引用第三方的C++類庫
首先,要到了Query歸一化的C++版本源代碼。
query歸一化
引用第三方的類庫有兩種方法,一種是靜態引用,一種是動態引用,推薦使用靜態引用,因為靜態引用的情況下,會把類庫打包到php的擴展.SO文件中,這樣我們不必擔心依賴關系,帶著類庫到處跑了。
先用gcc產生.o文件,再用.o產生 最終的靜態庫 .a 文件
gcc -c -fpic queryword.cpp tradmap.cpp transcode.cpp -I . -O2
ar -r libqueryword.a queryword.o tradmap.o transcode.o
❼ php中函數庫和類庫到底有什麼區別
首先你要知道什麼是函數,比如這一個
is_mail($str){//判斷的內容}
假如這個is_mail可以用來判斷用戶提交的數據是否是email格式的,這就是一個功能。判斷is_mail的功能。
使用的時候只要
if(is_mail($str))
{}
else
{}
函數庫
就是很多函數的集合。有很多功能,你就不用自己重新寫了,直接使用就可以。
而類庫,你要先理解類。
類,你可以理解為函數根據實際需求分類存放的一個地方。因為如果項目很大,就會有很多函數,如果不分類,有時候就很難找到了。根據函數的功能,把一類函數都整合到一個類裡面,使用起來就很方便。
比如資料庫操作類。
所有資料庫操作的函數都放在裡面了,你只要調用就可以了。
$db = new data();
$db->qurey();//使用$db類的qurey方法,其實就是使用qurey這個函數。
而類庫,就是很多可以直接使用的類。
總而言之,函數庫和類庫,可以大大提升開發效率。
❽ ajax調用PHP類庫中的函數
直接調用不可能,但可以繞過去調用
a.php
<?php
$_token = md5(time());//令牌
$_SESSION['_TOKEN'] = $_token;
//....
?>
<html>
...
<form>
<input name="_TOKEN" value="<?php print $_token; ?>">
....
//這里說一下令牌,令牌一般是伺服器端驗證提交數據是否為合法
//與驗證碼功能差不多,不過驗證碼需要手動輸入,這個是程序內部使用
...
處理post
<?php
if($_POST['_TOKEN'] == $_SESSION['_TOKEN'])
{
$_SESSION['_TOKEN'] = '';//清除令牌,防止網路延緩的再次提交。
...
}
?>
然後是ajax
上面我為什麼要在你原來的程序上加入令牌呢,因為可以隨意的調用php函數是很不安全的,很容易被有心人利用,所以做一點安全保護,當然不一定絕對安全
function _new_ajax()
{
//創建XMLHTTPRequests
return xhr;
}
function _ajax(_option)//url, data, type, async
{
//初始化
if(typeof _option.url == 'undefined' || _option.url == '')
{
alert('ajax錯誤,沒有定義請求路徑');
return false;
}
_option.data = _option.data || {};
_option.type = _option.type || 'GET';
_option.async = _option.async || true;
_option.callback = _option.callback || function(){};
//開始請求
var xhr = _new_ajax();
if(typeof _option.data == 'string')
{
_option.url += (_option.url.match(/\?/) ? "&" : "?") + _option.data;
}
else
{
for(var i in _option.data)
{
_option.url += (_option.url.match(/\?/) ? "&" : "?") + i + '=' + _option.data[i];
}
}
xhr.open(_option.type, _option.url, _option.async);
xhr.onreadystatechange = function(){
if(xhr.readyState == 4 && xhr.status == 200)
{
var res = xhr.responseText;
_option.callback(res);
}
};
xhr.send(null);
xhr = null;
}
上面的是我簡單寫的,估計考慮不是很全
驗證用戶是否存在就這樣
function check_user_id()
{
document.getElementById('useridexist').innerHTML = "Check the ID, Please wait...";
var user_id = document.login.userid.value;
//這里是上面說的,要直接使用函數庫,必須安全驗證
var _TOKEN = document.login._TOKEN.value;
_ajax({
url:'class/useridexist.php',
data:{_TOKEN:_TOKEN, function:check_user, id:user_id},//調用php函數check_user
callback:function(res){
document.getElementById('useridexist').innerHTML = res;
}
})
}
好了,准備就緒,現在看php端了
b.php
<?php
if($_GET['_TOKEN'] == $_SESSION['_TOKEN'])
{
//這里不清除令牌,因為提交post還要使用,驗證在前,提交post在後
$function = $_GET['function'];
if(function_exists($function))
{
$function($_GET);
}
else
{
print '函數'.$function.'不存在';
}
}
//以下為函數庫
function check_user($get)
{
//.....驗證存在否,輸出
}
?>
❾ php 怎麼用第三方類庫tcpdf
你可以是使用import方法載入第三方的類,然後直接new它的宏輪譽類名就行了,這樣蔽段試試呢如果不行, 你也可以去後盾人看看php基礎教學視頻看看,也是不錯的桐枝選擇,希望能幫到你,給個採納吧謝謝(๑•́ωก̀๑)