<li id="fz34h"><legend id="fz34h"></legend></li>
      1. <thead id="fz34h"></thead>
        <span id="fz34h"><optgroup id="fz34h"><xmp id="fz34h"></xmp></optgroup></span>
      2. 保存<\/a>
      3. \t刷新<\/a>
      4. \t重置<\/a>
      5. 退出<\/a>
      6. <\/div>
      7. {$tree}<\/div>
        {$code}<\/pre>
      8. 国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

        首頁 後端開發(fā) php教程 單檔版線上程式碼編輯器 aceditor

        單檔版線上程式碼編輯器 aceditor

        Jul 25, 2016 am 08:47 AM

        <li id="a8bjr"></li>
        * 單一檔案版線上程式碼編輯器editor.php 版本: v1.21
        * 非常方便地在線編輯您網(wǎng)站上的任意文字檔案,對於維護(hù)網(wǎng)站,和線上寫程式碼非常好用
        * 密碼加密方式:
        * md5(自設(shè)密碼$ace) //$ace為cdn鏡像位址
        *
        * 使用方法:
        * 1.確認(rèn)$pwd 變數(shù)值為false, 上傳本文件到PHP空間並存取
        * 2.第一次存取提示設(shè)定密碼,設(shè)定密碼並牢記
        * 3.使用第一次設(shè)定的密碼登入後,預(yù)設(shè)編輯的是本php檔案,
        * 4.本文件是編輯器核心檔,請不要隨意修改
        * 5.保存編輯的文件請用Ctrl S 按鍵組合,等待執(zhí)行結(jié)果
        * 6.保存動(dòng)作執(zhí)行後請務(wù)必等待保存成功資訊回傳
        * 7.重置操作會(huì)修改本程式的文件名,以防他人猜測路徑
        * 8.刷新功能僅是刷新本程式文件,不能刷新其他
        *
        *建議在chrome 瀏覽器中使用本編輯器

        項(xiàng)目詳細(xì)見
        http://git.oschina.net/ymk18/aceditor 單檔版線上程式碼編輯器 aceditor
        1. /**
        2. * 單檔版線上程式碼編輯器editor.php 版本: v1.21
        3. *
        4. * 密碼加密方式:
        5. * md5(自設(shè)密碼$ace) //$ace為cdn鏡像位址
        6. *
        7. * 使用方法:
        8. * 1.確認(rèn)$pwd 變數(shù)值為false, 上傳本檔案到PHP空間並存取
        9. * 2.第一次存取提示設(shè)定密碼,設(shè)定密碼並牢記
        10. * 3.使用第一次設(shè)定的密碼登入後,預(yù)設(shè)編輯的是本php檔案,
        11. * 4.本檔案是編輯器核心檔案,請不要隨意修改
        12. * 5.儲(chǔ)存編輯的檔案請用Ctrl S 按鍵組合,等待執(zhí)行結(jié)果
        13. * 6.儲(chǔ)存動(dòng)作執(zhí)行後請務(wù)必等待儲(chǔ)存成功資訊回傳
        14. * 7.重設(shè)操作會(huì)修改本程式的檔案名,以防他人猜測路徑
        15. * 8.刷新功能僅是刷新本程式文件,不能刷新其他
        16. *
        17. * 建議在chrome 瀏覽器中使用本編輯器
        18. */
        19. session_start();
        20. $curr_file = __FILE__; //預(yù)設(shè)編輯目前檔案
        21. $curr_file_path = str_replace(dirname(__FILE__), '', __FILE__);
        22. $pwd = false; //密碼初始化預(yù)設(shè)值為false
        23. $ace = 'http://cdn.staticfile.org/ace /1.1.3/ace.js'; //編輯器核心js
        24. $tip['core'] = 'http://cdn.staticfile.org/alertify.js/0.3.11/alertify.core. min.css';
        25. $tip['css'] = 'http://cdn.staticfile.org/alertify.js/0.3.11/alertify.default.min.css';
        26. $tip[ 'js'] = 'http://cdn.staticfile.org/alertify.js/0.3.11/alertify.min.js';
        27. $jquery = 'http://cdn.staticfile.org/jquery/ 2.1.1-rc2/jquery.min.js';
        28. if ( false !== $pwd ) {
        29. define('DEFAULT_PWD', $pwd);
        30. }
        31. //檔案後綴名對應(yīng)的語法解析器
        32. $lng = array(
        33. 'as' => 'actionscript', 'js' => 'javascript',
        34. 'php' => ' php', 'css' => 'css', 'html' => 'html',
        35. 'htm' => 'html', 'ini' => 'ini', 'json' => 'json' ,
        36. 'jsp' => 'jsp', 'txt' => 'text', 'sql' => 'mysql',
        37. 'xml' => 'xml', 'yaml' => 'yaml ', 'py' => 'python',
        38. 'md' => 'markdown', 'htaccess' => 'apache_conf',
        39. 'bat' => 'batchfile', 'go' => ' golang',
        40. );
        41. //判斷使用者是否登入
        42. function is_logged() {
        43. $flag = false;
        44. if ( isset($_SESSION['pwd'] ) && defined('DEFAULT_PWD') ) {
        45. if ( $_SESSION['pwd'] === DEFAULT_PWD ) {
        46. $flag = true;
        47. }
        48. }
        49. $flag = true;
        50. }
        51. }
        52. return $laglag; ;
        53. }
        54. //重新載入至本頁
        55. function reload() {
        56. $file = pathinfo(__FILE__, PATHINFO_BASENAME);
        57. die(header("Location: {$file}"));
        58. }
        59. //判斷請求是否為ajax請求
        60. function is_ajax() {
        61. $flag = false;
        62. if ( isset($ _SERVER['HTTP_X_REQUESTED_WITH']) ) {
        63. $flag = strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) === 'xmlhttprequest';
        64. }
        65. return $flag;
        66. //銷毀SESSION和COOKIE
        67. function exterminate() {
        68. $_SESSION = array();
        69. foreach ( $_COOKIE as $key ) {
        70. setcookie($key, null);
        71. }
        72. session_destroy();
        73. $_COOKIE = array();
        74. return true;
        75. }
        76. //取得目錄下的檔案清單
        77. }
        78. //取得一個(gè)目錄下的檔案清單
        79. function??>function??>function??>function??>function??>function??>function??>function??>function??>function??>function list_dir($path, $type = 'array') {
        80. $flag = false;
        81. $lst = array('dir'=>array(), 'file'=>array());
        82. $base = !is_dir($path) ? dirname($path) : $path;
        83. $tmp = scandir($base);
        84. foreach ( $tmp as $k=>$v ) {
        85. //過濾掉上級目錄,本級目錄與程式本身檔名
        86. if ( !in_array($v, array('.', '..')) ) {
        87. $file = $full_path = rtrim($base, '/').DIRECTORY_SEPARATOR.$v;
        88. if ( $full_path == __FILE__ ) {
        89. continue; //屏蔽自身檔案不在列表中出現(xiàn)
        90. } $file = str_replace(dirname(__FILE__), '', $file);
        91. $file = str_replace("\", '/', $file); //過濾win下的路徑
        92. $file = str_replace(' //', '/', $file); //過濾雙斜線
        93. if ( is_dir($full_path) ) {
        94. if ( 'html' === $type ) {
        95. $v = '
        96. '.$v.'
        97. ';
        98. }
        99. array_push($lst['dir'], $v);
        100. } else {
        101. if ( 'html' === $type ) {
        102. $v = ' .'" onclick="load()">'.$v.'
        103. ';
        104. }
        105. array_push($lst['file'], $v);
        106. }
        107. }
        108. }
        109. $lst = array_merge($lst['dir'], $lst['file ']);
        110. $lst = array_filter($lst);
        111. $flag = $lst;
        112. if ( 'html' === $type ) {
        113. $flag = '
            '. implode('', $lst) .'
          '; } return $flag;}
        114. //遞歸刪除一個(gè)非空白目錄
        115. function deldir($dir) {
        116. $dh = opendir($dir);
        117. while ( $file = readdir($dh) ) {
        118. if ( $file != '.' && $file != '..' ) {
        119. $fullpath = $dir.'/'.$file;
        120. if ( !is_dir($fullpath ) ) {
        121. unlink($fullpath);
        122. } else {
        123. deldir($fullpath);
        124. }
        125. }
        126. }
        127. return rmdir($dir); ??>}
        128. //登出登入
        129. if ( isset($_GET['logout']) ) {
        130. if (exterminate() ) {
        131. reload();
        132. }
        133. }
        134. //ajax輸出檔案內(nèi)容
        135. if ( is_logged() && is_ajax() && isset($_POST['file']) ) {
        136. $file = dirname( __FILE__).$_POST['file'];
        137. $ext = pathinfo($file, PATHINFO_EXTENSION);
        138. $mode = isset($lng[$ext]) ? $lng[$ext] : false;
        139. die(json_encode(array(
        140. 'file' => $file, 'html' => file_get_contents($file),
        141. 'mode' => $mode,
        142. )));
        143. }
        144. //ajax輸出目錄清單
        145. if ( is_logged() && is_ajax() && isset($_POST['dir']) ) {
        146. $dir = dirname(__FILE__) .$_POST['dir'];
        147. $list_dir = list_dir($dir, 'html');
        148. die(json_encode(array(
        149. 'dir' => $dir, 'html' => $list_dir,
        150. )));
        151. }
        152. //ajax儲(chǔ)存檔案
        153. if ( is_logged() && is_ajax() && isset($_POST['action']) ) {
        154. $arr = array('result'=>'error', 'msg'=>'檔案儲(chǔ)存失?。?');
        155. $content = $_POST['content'];
        156. if ( 'save_file' === $_POST['action'] ) {
        157. if (isset($_POST['file_path' ]) ) {
        158. $file = dirname(__FILE__).$_POST['file_path'];
        159. } else {
        160. $file = __FILE__;
        161. }
        162. file_put_contents($file, $ content);
        163. $arr['result'] = 'success';
        164. $arr['msg'] = '保存成功! ';
        165. }
        166. die(json_encode($arr));
        167. }
        168. //ajax刪除檔案或資料夾
        169. if ( is_logged() && is_ajax() && isset() && isset ($_POST['del']) ) {
        170. $path = dirname(__FILE__).$_POST['del'];
        171. $arr = array('result'=>'error', 'msg' =>'刪除操作失??! ');
        172. if ( $_POST['del'] && $path ) {
        173. $flag = is_dir($path) ? deldir($path) : unlink($path) ;
        174. if ( $flag ) {
        175. $arr['msg'] = '刪除操作成功! ';
        176. $arr['result'] = 'success';
        177. }
        178. }
        179. die(json_encode($arr));
        180. }
        181. //ajax新檔案或資料夾
        182. if ( is_logged() && is_ajax() && isset($_POST['create']) ) {
        183. $flag = false;
        184. $arr = array('result'= >'error', 'msg'=>'操作失??! '];
        185. $target = is_dir($target) ? $target : dirname($target);
        186. }
        187. if ( $_POST['create'] && $target ) {
        188. $base_name = pathinfo($_POST['create'], PATHINFO_BASENAME);
        189. $exp = explode('.', $base_name);
        190. $full_path = $target.'/'.$base_name;
        191. $full_path = $target.'/'.$base_name;
        192. $ new_path = str_replace(dirname(__FILE__), '', $full_path);
        193. if ( count($exp) > 1 && isset($lng[array_pop($exp)]) ) {
        194. file_put_contents($full_path , '');
        195. $arr['result'] = 'success';
        196. $arr['msg'] = '新建文件成功! ';
        197. $arr['type'] = 'file';
        198. } else {
        199. mkdir($full_path, 0777, true);
        200. $arr['result'] = 'success' ;
        201. $arr['msg'] = '新建目錄成功! ';
        202. $arr['type'] = 'dir';
        203. }
        204. if ( $base_name && $new_path ) {
        205. $arr['new_name'] = $base_name;
        206. $arr['new_path'] = $new_path;
        207. }
        208. }
        209. die(json_encode($arr));
        210. }
        211. //ajax重命名檔案或資料夾
        212. if ( is_logged() && is_ajax() && isset($_POST['rename']) ) {
        213. $arr = array('result'=>'error', 'msg'=>'重新命名操作失敗! ( $_POST['rename'] ) {
        214. $base_name = pathinfo($_POST['rename'], PATHINFO_BASENAME);
        215. if ( $base_name ) {
        216. $rename = dirname($target). '/'.$base_name;
        217. $new_path = str_replace(dirname(__FILE__), '', $rename);
        218. }
        219. }
        220. if ( $rename && $target && rename($target , $rename) ) {
        221. $arr['new_name'] = $base_name;
        222. $arr['new_path'] = $new_path;
        223. $arr['msg'] = '重命名操作成功!';
        224. $arr['result'] = '成功';
        225. }
        226. if ( $target == __FILE__ ) {
        227. $arr['redirect'] = $new_path;
        228. }
        229. die(json_encode($arr));
        230. }
        231. //取得程式碼檔案內(nèi)容
        232. $code = file_get_contents($curr_file);
        233. $tree = '
        234. ROOT'.list_dir($curr_file, 'html').' li>
        235. ';
        236. //登陸與設(shè)定密碼消耗模版
        237. $first =
        238. 【標(biāo)題】
        239. HTMLSTR;
        240. //判斷是否第一次登入
        241. if ( false === $pwd &&empty($_POST) ) {
        242. die(str_replace(
        243. array('【標(biāo)題】', '【動(dòng)作】'),
        244. array('第一次使用,請先設(shè)定密碼!', '設(shè)定'),
        245. $first
        246. ));
        247. }
        248. //第一次設(shè)定登入密碼
        249. if ( false === $pwd && !empty ($_POST) ) {
        250. if ( isset($_POST['pwd']) && strlen($_POST['pwd']) ) {
        251. $pwd = $_SESSION['pwd'] = md5( $_POST['pwd'].$ace);
        252. $code = preg_replace('#$pwd = false;#', '$pwd = "'.$pwd.'";', $code, 1) ;
        253. file_put_contents($curr_file, $code);
        254. } else {
        255. reload();
        256. }
        257. }
        258. //使用者登入驗(yàn)證
        259. if ( false !== $pwd && !empty($_POST) ) {
        260. $tmp = md5($_POST['pwd'].$ace);
        261. if ( $tmp && $pwd && $tmp == = $pwd ) {
        262. $_SESSION['pwd'] = $pwd;
        263. reload();
        264. }
        265. }
        266. //處理一下html實(shí)體
        267. $ code = htmlspecialchars($code);
        268. $dir_icon = str_replace(array("rn", "r", "n"), '',
        269. ' 4kAAAAGXRFWHRTb2Z0d2
        270. FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAQVJREFUeNqkkk1uwjAQhd84bsNP1FUXLCtu0H3XPSoX4Qrd9wRPeVA/Sy6Dw555q3au1z EhBYk1cgO7OSNdaFNT0x5sCkYDha0WPiLOHyqPwemAiLO h3HqH7BctFWLMOmAbcg05mHK5 sQpd1HYijN47zcDUCShGEHtzxtwQS9WTcAQmJROrJDLXQB9s1Tu6
        271. MtRED4bwsHLnUzxEeKac3wuP63838E)ExExSacxB]
        272. $file_icon = str_replace(array(" rn", "r", "n"), '',
        273. '
        274. FyZQBBZG9iZCJGbKJGGJ ez7aYbNwreQdBzeopS6EXEW jug7Z
        275. C6X /iUloSr6xioFHJkPee5mUJgBwT7gjpPB3XAgfiBjs5dOyLF/btl0pkEFngdbzPGNRFKRFPB3XAgfiBjs5dOyLF/btl0pkEFngdbzPGNRFRFK/Umhw kDJor6uq2SGktu2FfdpmpANqqoSASYnO/kthABJkoCOxCASkCBkWSYuQ
        276. qCeNE1fqHz3fMkXzjnJ2sRinL33QBNIzWJ5nh/L8npQohVTJwYTyfFm/d6Oo2HGE8ffwseuZ1PEjhrOutmsRF
        277. 0iC8QmPib??i4i??nft 33DkbN1sws0i Pega6v0kd42H9JB/8
        278. LJl5I6PNbgAEAa9MP7QWoNLoAAAAASUVORK5CYII=');
        279. $loading = str_replace(array("rn" n"), '',
        280. ' TMsZiALlcAKNOAOp4ANVqAP PFv///wAAAAAAAA
        281. AAAAAAAAAAAAAAAAAAACH/C05FVFNDQVBFMi4wAwEAAAAh QQFCgAIACwAAAAAFAAUAAAEUxDJSau9iBDMteb
        282. TMEjehgTBJYqkiaLWOlZvGs8WDO6UIPCHw8TnAwWDEuKPcxQml0Ynj2cwYACAS7VqwWItWyuiUJB4s2AxmWxG
        283. g9bl6YQtl0cAACH5BAUKAAgALAEAAQASABIAAAROEMkpx6A4W5upENUmEQT2feFIltMJYivbvhnZ3Z1h4FMQI
        284. Dodz cL7nDEn5CH8DGZhcLtcMBEoxkqlXKVIgAAibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAA
        285. ROEMkphaA4W5upMdUmDQP2feFIltMJYivbvhnZ3V1R4BNBIDodz cL7nDEn5CH8DGZAMAtEMBEoxkqlXKVIg4
        286. HibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpjaE4W5tpKdUmCQL2feFIltMJYivbvhnZ qlXKVIgIBibbK9YLBYvLtHH5K0J0IACH5BAUKAAgALAEAA
        287. QASABIAAAROEMkpS6E4W5spANUmGQb2feFIltMJYivbvhnZ3d1x4JMgIDodzmGQb2feFIltMJYivbvhnZ3d1x4JMgIDodz tHH5K0J0IACH5BAUKAAgALAEAAQASABIAAAROEMkpAaA4W5vpOdUmFQX2feFIltM
        288. JYivbvhnZ3V0Q4JNhIDodz AQASABIAAAROEMkpz6E4W5tpCNUmAQD2feFIltMJYivbvhnZ3R1B4FNRIDodz cL7nDEn5CH8DGZg
        289. 8HNYMBEoxkqlXKVIgQCiASAK9YLBYvL75KJLBYv f2feFIltMJYivbvhnZ3d0w4BMAIDodz cL7nDEn5CH8DGZAsGtUMBEoxkqlXKVIgwGibbK9YLBYvLtHH5K0J0
        290. IADs=');
        291. //編輯器模版
        292. $html =
        293. ACE程式碼編輯器
        294. 保存
        295. 刷新
        296. 重置
        297. 退出
      9. {$tree}
        {$code}
      10. 熱AI工具

        Undress AI Tool

        Undress AI Tool

        免費(fèi)脫衣圖片

        Undresser.AI Undress

        Undresser.AI Undress

        人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

        AI Clothes Remover

        AI Clothes Remover

        用於從照片中去除衣服的線上人工智慧工具。

        Clothoff.io

        Clothoff.io

        AI脫衣器

        Video Face Swap

        Video Face Swap

        使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

        熱工具

        記事本++7.3.1

        記事本++7.3.1

        好用且免費(fèi)的程式碼編輯器

        SublimeText3漢化版

        SublimeText3漢化版

        中文版,非常好用

        禪工作室 13.0.1

        禪工作室 13.0.1

        強(qiáng)大的PHP整合開發(fā)環(huán)境

        Dreamweaver CS6

        Dreamweaver CS6

        視覺化網(wǎng)頁開發(fā)工具

        SublimeText3 Mac版

        SublimeText3 Mac版

        神級程式碼編輯軟體(SublimeText3)

        熱門話題

        Laravel 教程
        1601
        29
        PHP教程
        1502
        276
      11. PHP變量範(fàn)圍解釋了 PHP變量範(fàn)圍解釋了 Jul 17, 2025 am 04:16 AM

        PHP變量作用域常見問題及解決方法包括:1.函數(shù)內(nèi)部無法訪問全局變量,需使用global關(guān)鍵字或參數(shù)傳入;2.靜態(tài)變量用static聲明,只初始化一次並在多次調(diào)用間保持值;3.超全局變量如$_GET、$_POST可在任何作用域直接使用,但需注意安全過濾;4.匿名函數(shù)需通過use關(guān)鍵字引入父作用域變量,修改外部變量則需傳遞引用。掌握這些規(guī)則有助於避免錯(cuò)誤並提升代碼穩(wěn)定性。

        如何在PHP中牢固地處理文件上傳? 如何在PHP中牢固地處理文件上傳? Jul 08, 2025 am 02:37 AM

        要安全處理PHP文件上傳需驗(yàn)證來源與類型、控製文件名與路徑、設(shè)置服務(wù)器限制並二次處理媒體文件。 1.驗(yàn)證上傳來源通過token防止CSRF並通過finfo_file檢測真實(shí)MIME類型使用白名單控制;2.重命名文件為隨機(jī)字符串並根據(jù)檢測類型決定擴(kuò)展名存儲(chǔ)至非Web目錄;3.PHP配置限制上傳大小及臨時(shí)目錄Nginx/Apache禁止訪問上傳目錄;4.GD庫重新保存圖片清除潛在惡意數(shù)據(jù)。

        在PHP中評論代碼 在PHP中評論代碼 Jul 18, 2025 am 04:57 AM

        PHP註釋代碼常用方法有三種:1.單行註釋用//或#屏蔽一行代碼,推薦使用//;2.多行註釋用/.../包裹代碼塊,不可嵌套但可跨行;3.組合技巧註釋如用/if(){}/控制邏輯塊,或配合編輯器快捷鍵提升效率,使用時(shí)需注意閉合符號和避免嵌套。

        發(fā)電機(jī)如何在PHP中工作? 發(fā)電機(jī)如何在PHP中工作? Jul 11, 2025 am 03:12 AM

        AgeneratorinPHPisamemory-efficientwaytoiterateoverlargedatasetsbyyieldingvaluesoneatatimeinsteadofreturningthemallatonce.1.Generatorsusetheyieldkeywordtoproducevaluesondemand,reducingmemoryusage.2.Theyareusefulforhandlingbigloops,readinglargefiles,or

        撰寫PHP評論的提示 撰寫PHP評論的提示 Jul 18, 2025 am 04:51 AM

        寫好PHP註釋的關(guān)鍵在於明確目的與規(guī)範(fàn),註釋應(yīng)解釋“為什麼”而非“做了什麼”,避免冗餘或過於簡單。 1.使用統(tǒng)一格式,如docblock(/*/)用於類、方法說明,提升可讀性與工具兼容性;2.強(qiáng)調(diào)邏輯背後的原因,如說明為何需手動(dòng)輸出JS跳轉(zhuǎn);3.在復(fù)雜代碼前添加總覽性說明,分步驟描述流程,幫助理解整體思路;4.合理使用TODO和FIXME標(biāo)記待辦事項(xiàng)與問題,便於後續(xù)追蹤與協(xié)作。好的註釋能降低溝通成本,提升代碼維護(hù)效率。

        學(xué)習(xí)PHP:初學(xué)者指南 學(xué)習(xí)PHP:初學(xué)者指南 Jul 18, 2025 am 04:54 AM

        易於效率,啟動(dòng)啟動(dòng)tingupalocalserverenverenvirestoolslikexamppandacodeeditorlikevscode.1)installxamppforapache,mysql,andphp.2)uscodeeditorforsyntaxssupport.3)

        如何通過php中的索引訪問字符串中的字符 如何通過php中的索引訪問字符串中的字符 Jul 12, 2025 am 03:15 AM

        在PHP中獲取字符串特定索引字符可用方括號或花括號,但推薦方括號;索引從0開始,超出範(fàn)圍訪問返回空值,不可賦值;處理多字節(jié)字符需用mb_substr。例如:$str="hello";echo$str[0];輸出h;而中文等字符需用mb_substr($str,1,1)獲取正確結(jié)果;實(shí)際應(yīng)用中循環(huán)訪問前應(yīng)檢查字符串長度,動(dòng)態(tài)字符串需驗(yàn)證有效性,多語言項(xiàng)目建議統(tǒng)一使用多字節(jié)安全函數(shù)。

        快速PHP安裝教程 快速PHP安裝教程 Jul 18, 2025 am 04:52 AM

        ToinstallPHPquickly,useXAMPPonWindowsorHomebrewonmacOS.1.OnWindows,downloadandinstallXAMPP,selectcomponents,startApache,andplacefilesinhtdocs.2.Alternatively,manuallyinstallPHPfromphp.netandsetupaserverlikeApache.3.OnmacOS,installHomebrew,thenrun'bre

        See all articles

        <label id="a8bjr"></label>

            <li id="a8bjr"><meter id="a8bjr"></meter></li>