當(dāng)前位置:首頁 > 芯聞號 > 充電吧
[導(dǎo)讀]首先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. ?復(fù)制.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默認(rèn)是不支持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##開始的,請自行百度,關(guān)于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成功!";
}


最后關(guān)于 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);
????}


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

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

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

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉