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

當(dāng)前位置:首頁 > 芯聞號(hào) > 充電吧
[導(dǎo)讀]首先win7 環(huán)境是必須的,這里就不說如何安裝OS了,請(qǐng)自行百度1. 安裝 phpStudy,這是我第一次聽說這個(gè)軟件,看起來真的不錯(cuò),可以自行選擇版本將運(yùn)行環(huán)境進(jìn)行打包處理,這里直接選擇php 7.

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

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

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

3.因?yàn)閏omposer源的問題可以直接換源,執(zhí)行以下命令

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


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

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


?composer?install


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



copy?.env.example?.env


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


?php?artisan?key:generate


8. ?接下來是進(jìn)行php study的修改,將站點(diǎn)目錄修改為?D:\runninglarave\public


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


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


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


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

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

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

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

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

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

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


oci8.privileged_connect?=?On


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


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

? ??在 ?IlluminateDatabaseConnectorsConnectionFactory.php ; 添加兩個(gè)類的聲明


use?YajraOci8ConnectorsOracleConnector;
use?YajraOci8Oci8Connection;

? ? 還是這個(gè)文件還需要重寫兩個(gè)函數(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',?''),
????????],

同時(shí)修改default ?



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


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


測(cè)試代碼:


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



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


$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連接的測(cè)試代碼



$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的方式進(jìn)行連接


?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方式進(jìn)行連接

OK: ? ?我的整個(gè)搭建過程到此為止,如有問題敬請(qǐng)留言!

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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