www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > > 充電吧
[導讀]首先win7 環(huán)境是必須的,這里就不說如何安裝OS了,請自行百度1. 安裝 phpStudy,這是我第一次聽說這個軟件,看起來真的不錯,可以自行選擇版本將運行環(huán)境進行打包處理,這里直接選擇php 7.

首先win7 環(huán)境是必須的,這里就不說如何安裝OS了,請自行百度

1. 安裝 phpStudy,這是我第一次聽說這個軟件,看起來真的不錯,可以自行選擇版本將運行環(huán)境進行打包處理,這里直接選擇php 7.0.12-nts+nginx即可

2. 開始安裝composer ?,下載地址是 ?https://getcomposer.org/Composer-Setup.exe,一路確定即可

3.因為composer源的問題可以直接換源,執(zhí)行以下命令

??composer?config?-g?repo.packagist?composer?https://packagist.phpcomposer.com


4. 下載laravel5.3 版本,下載地址是:https://github.com/laravel/laravel ? 并將其加壓縮到你需要的位置上即可,我是 D:\runninglaravel

5. 進行composer安裝 ,使用cmd 進入到?D:\runninglaravel 目錄下,執(zhí)行命令:


?composer?install


6. ?復制.env.example 為.env文件,執(zhí)行命令



copy?.env.example?.env


7. ?執(zhí)行命令:


?php?artisan?key:generate


8. ?接下來是進行php study的修改,將站點目錄修改為?D:\runninglarave\public


9. 修改nginx.conf 其目的是將所有的請求定位到publicindex.php文件上進行統(tǒng)一處理


??location?/?{
??????????????root?"D:/running/laravel/public";
????????????index??index.php;
????????????if?(!-e?$request_filename)?{?
????????????rewrite?^(.*)$?/index.php?s=$1?last;?
????????????break;?
????????????}
????????}


這是我的處理文件,很糙,但是目前可用


10. 到這里為止,再檢查一下php的擴展 ?需要打開的是open_ssl (這個我遇到過問題,即使打開了也會報錯 encry**函數(shù)未定義,我的處理方式是重啟電腦)

11. laravel已經(jīng)安裝好,現(xiàn)在需要做的是進行l(wèi)aravel的oracle支持,laravel默認是不支持oracle的,現(xiàn)在添加第三方的組件

? ??? ?composer require yajra/laravel-oci8

12. 如果要用php連接oracle不光需要php擴展,還需要oracle的客戶端程序,

? 下載文件:http://download.oracle.com/otn/nt/instantclient/121020/instantclient-basic-nt-12.1.0.2.0.zip?AuthParam=1488258321_c18d9fdc85acf4d32185f80bcd7e3b5a

? ? 同時還需要將文件解壓縮后,并將解壓縮位置添加在環(huán)境變量上

13. 開啟php ?擴展, 打開php_oci ?php_oci_11g ? php_pdo_oci,需要注意的還有就是打開 ?


oci8.privileged_connect?=?On


? ? ?允許oci_connect連接,這樣就同時支持了兩種方式一個是pdo方式,第二個是開啟oci_connnect連接方式


14. 雖然框架中已經(jīng)有了對oracle的支持,但是在接入點還需要進行修改

? ??在 ?IlluminateDatabaseConnectorsConnectionFactory.php ; 添加兩個類的聲明


use?YajraOci8ConnectorsOracleConnector;
use?YajraOci8Oci8Connection;

? ? 還是這個文件還需要重寫兩個函數(shù)



????protected?function?createConnection($driver,?$connection,?$database,?$prefix?=?'',?array?$config?=?[])
????{
????????if?($resolver?=?Connection::getResolver($driver))?{
????????????return?$resolver($connection,?$database,?$prefix,?$config);
????????}

????????switch?($driver)?{
????????????case?'mysql':
????????????????return?new?MySqlConnection($connection,?$database,?$prefix,?$config);
????????????case?'pgsql':
????????????????return?new?PostgresConnection($connection,?$database,?$prefix,?$config);
????????????case?'sqlite':
????????????????return?new?SQLiteConnection($connection,?$database,?$prefix,?$config);
????????????case?'sqlsrv':
????????????????return?new?SqlServerConnection($connection,?$database,?$prefix,?$config);
????????????case?'oracle':
????????????????return?new?Oci8Connection($connection,?$database,?$prefix,?$config);;
????????}
????????throw?new?InvalidArgumentException("Unsupported?driver?[$driver]");
????}
}


public?function?createConnector(array?$config)
????{
????????if?(!?isset($config['driver']))?{
????????????throw?new?InvalidArgumentException('A?driver?must?be?specified.');
????????}

????????if?($this->container->bound($key?=?"db.connector.{$config['driver']}"))?{
????????????return?$this->container->make($key);
????????}

????????switch?($config['driver'])?{
????????????case?'mysql':
????????????????return?new?MySqlConnector;
????????????case?'pgsql':
????????????????return?new?PostgresConnector;
????????????case?'sqlite':
????????????????return?new?SQLiteConnector;
????????????case?'sqlsrv':
????????????????return?new?SqlServerConnector;
????????????case?'oracle':
???????????????return?new?OracleConnector;
????????}

????????throw?new?InvalidArgumentException("Unsupported?driver?[{$config['driver']}]");
????}


最后就是修改config中database.php文件中的配置了, ? ?



??'oracle'?=>?[
????????????'driver'????????=>?'oracle',
????????????'tns'???????????=>?env('DB_TNS',?''),
????????????'host'??????????=>?'192.168.11.111',
????????????'port'??????????=>?1521,
????????????'database'??????=>?'ORCL',
????????????'username'??????=>?"c##test1",
????????????'password'??????=>?'111111',
????????????'charset'???????=>?env('DB_CHARSET',?'AL32UTF8'),
????????????'prefix'????????=>?env('DB_PREFIX',?''),
????????????'prefix_schema'?=>?env('DB_SCHEMA_PREFIX',?''),
????????],

同時修改default ?



????'default'?=>?'oracle',


至于用戶名是C##開始的,請自行百度,關于CDB和PDB的區(qū)別


測試代碼:


Route::get('test',?function?()?{
$m?=?DB::table("users_data")->get();
var_dump($m->all());
});



PS: ? 現(xiàn)在附上PDO方式的連接測試代碼


$tns?=?"??
(DESCRIPTION?=
????(ADDRESS_LIST?=
??????(ADDRESS?=?(PROTOCOL?=?TCP)(HOST?=?192.168.11.111)(PORT?=?1521))
????)
????(CONNECT_DATA?=
??????(Service_Name?=?orcl)
????)?
??)?";
$db_username?=?"C##test1";???#這里不能使用?sys角色的用戶
$db_password?=?"111111";
try?{
????$conn?=?new?PDO("oci:dbname="?.?$tns,?$db_username,?$db_password);
}?catch?(PDOException?$e)?{
????echo($e->getMessage());
}
$sql?=?"select?*?from?users_data";
$rs?=?$conn->query($sql);
$m?=?$rs->fetchAll();


oci_connect連接的測試代碼



$conn?=?oci_connect('C##test1',?'111111',?'192.168.11.111/orcl');
if?(!$conn)?{
????$e?=?oci_error();
????print?htmlentities($e['message']);
????exit;
}else?{
????echo?"連接oracle成功!";
}


最后關于 laravel框架連接oracle的方式是使用oci_connect的方式進行連接


?public?function?createConnection($tns,?array?$config,?array?$options)
????{
????????//?add?fallback?in?case?driver?is?not?set,?will?use?pdo?instead
????????if?(!?in_array($config['driver'],?['oci8',?'pdo-via-oci8',?'oracle']))?{
????????????return?parent::createConnection($tns,?$config,?$options);
????????}

????????$config?????????????=?$this->setCharset($config);
????????$options['charset']?=?$config['charset'];

????????return?new?Oci8($tns,?$config['username'],?$config['password'],?$options);
????}


如果當初并未設定oracle或者oci8 ?或者pdo-via-oci8的話,則使用PDO方式,否則使用oci8的oci_connect方式進行連接

OK: ? ?我的整個搭建過程到此為止,如有問題敬請留言!

本站聲明: 本文章由作者或相關機構(gòu)授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅(qū)動電源的性能直接關系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設計中至關重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅(qū)動性能的關鍵。

關鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關鍵字: LED 設計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關鍵元件,其性能直接影響到電動汽車的動力性能和...

關鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質(zhì)量和效率直接關系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關鍵字: LED照明技術 電磁干擾 驅(qū)動電源

開關電源具有效率高的特性,而且開關電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關鍵字: LED 驅(qū)動電源 開關電源

LED驅(qū)動電源是把電源供應轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關鍵字: LED 隧道燈 驅(qū)動電源
關閉