国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解nodejs 文本操作模塊-fs模塊(一)

2019-11-19 18:19:18
字體:
來源:轉載
供稿:網友

JS的安全性問題,就決定了JS想要取操作數據庫操作文件是不可實現的,而Nodejs作為服務端的JS,如果依然不能操作文件,那么又如何稱之為服務端語言呢,所以在Nodejs中,提供了一個fs(File System)模塊,以實現文件及目錄的讀寫操作。

寫在前面

Nodejs的一大優勢就在于,支持異步調用,不管是在讀取數據庫,還是在讀取文件時,都可以使用異步的方式進行處理,這樣就可以處理高并發的情況,從本篇開始,開始對Nodejs的fs模塊中,一些重要的API,結合源碼,進行一些說明學習。

fs模塊支持的屬性和方法

fs模塊是一個很重要的模塊,也支持非常多的屬性和方法,可以直接在nodejs中查看,fs模塊支持的屬性,創建一個app.js文件,輸入以下代碼,運行即可。

var fs = require("fs"),  i;   for(i in fs){  console.log(i); } 

由于fs的家族子弟太多,這里就不一一列舉了,下面就開始介紹一下fs家族的核心子弟。

1:open和openSync方法

對于文件操作,最基本的莫過于打開文件,你想要讀寫文件,那么就必須要打開文件才能讀寫,就像你要往冰箱放東西或者從冰箱拿東西,那么你首先要打開冰箱才行。

所以,這里就以文件的打開為首個屬性,來進入文件模塊。

文件操作中,分為同步操作和異步操作,它們的命名規則都是相同的,比如這里,open方法是異步方法,同步的方法是在異步方法的基礎上,添加一個”Sync“的后綴,也就是這里的openSync,還有讀取文件時也是,readFile和readFileSync等,這個在后面不再多說,并且它們的使用基本上也是相同的,唯一的差距在于異步的數據是以第二個參數的形式傳入回調函數,而同步的方法,返回值就是處理的結果數據。

下面,就會以open和openSync為基礎,把這些都說明一下。

open和openSync的使用方法:

var fs = require("fs");  fs.open(filename,flags,[mode],callback);  //同步打開文件 var fs = openSync(filename,flags,[mode]); 

以open方法的使用方式為例,open方法中,可以使用4個參數,其中filename參數,flags參數,callback參數是必須指定的參數,mode參數為可選參數。

其中:

filename是你所要讀取文件的路徑,可以是絕對路徑,也可以是相對路徑,這個就看你喜好了。

callback為打開文件成功后,執行的回調函數,回調函數的格式為:

function(err , data){ //err為讀取文件失敗時,觸發的錯誤對象 //data為回調函數的可用數據。 //在open的回調函數中,data是一個整數值,代表打開文件時返回的文件描述符(文件句柄)。 //每一個文件,都有唯一的文件描述符(句柄)。 } 

基本上,在fs模塊中的所有異步執行函數的回調函數,都是這樣的格式,唯一的差距就是在于回調函數的第二個數據,也就是操作成功后,得到的數據的差別,在以后的內容中,對該部分,就不再多說。

mode為可選參數,用于指定當文件被打開時,對該文件的讀寫權限,默認值為0666(可讀寫),該方法使用4個數字組成mode屬性值,它們的組成方式符合以下規則:

第一個數字必須是0,表示該數據是一個八進制的數字。

第二個數字,用于規定文件或者目錄所有者的權限。

第三個數字,用于規定文件或者目錄所有者所屬用戶組的權限。

第四個數字,規定其他人的權限。

對于上述的第二,第三,第四個數字,讀寫權限的設置符合以下規則。

設置為1:表示為執行權限。

設置為2:表示有寫權限。

設置為4:表示有毒權限。

如果需要設置有執行權限和寫權限,則數字設置為3,如果只想要有讀寫權限,則設置為6,即,你想要哪些權限,你就把上述代表權限的數字相加即可。如果設置,需要執行權限,讀寫權限,則可以設置為7,默認狀態為設置為6,即擁有讀寫權限。
open方法支持的另外一個參數flags,表示該對象,可以對文件執行哪些操作,支持的屬性過多,所以放到一個列表中了:

屬性 意義
r 以【只讀】的方式打開文件. 當文件不存在時產生異常
r+ 以【讀寫】的方式打開文件. 當文件不存在時產生異常
rs 同步模式下,以【只讀】的方式打開文件. 指令繞過操作系統的本地文件系統緩存。該功能主要用于打開 NFS 掛載的文件, 因為它可以讓你跳過默認使用的過時本地緩存. 但這實際上非常影響 I/O 操作的性能, 因此除非你確實有這樣的需求, 否則請不要使用該標志。注意: 這并不意味著 fs.open() 變成了一個同步阻塞的請求. 如果你想要一個同步阻塞的請求你應該使用 fs.openSync()。
rs 同步模式下,以【只讀】的方式打開文件. 指令繞過操作系統的本地文件系統緩存。該功能主要用于打開 NFS 掛載的文件, 因為它可以讓你跳過默認使用的過時本地緩存. 但這實際上非常影響 I/O 操作的性能, 因此除非你確實有這樣的需求, 否則請不要使用該標志。注意: 這并不意味著 fs.open() 變成了一個同步阻塞的請求. 如果你想要一個同步阻塞的請求你應該使用 fs.openSync()。
rs+ 同步模式下, 以【讀寫】的方式打開文件. 請謹慎使用該方式, 詳細請查看 ‘rs' 的注釋.
w 以【只寫】的形式打開文件. 文件會被創建 (如果文件不存在) 或者覆蓋 (如果存在).
wx 作用與”w”類似,區別是如果文件存在則操作會失?。ū仨毴摻ㄒ粋€新的文件才行)
w+ 以【讀寫】的方式打開文件. 文件會被創建 (如果文件不存在) 或者覆蓋 (如果存在).
wx+ 作用與”w+”類似,區別是如果文件存在則操作會失敗(必須去創建一個新的文件才行)
a 以【附加】的形式打開文件,即新寫入的數據會附加在原來的文件內容之后. 如果文件不存在則會默認創建.
ax 作用與”a”類似,區別是如果文件存在則操作會失?。ū仨毴摻ㄒ粋€新的文件才行)
a+ 以【讀取】和【附加】的形式打開文件. 如果文件不存在則會默認創建.
ax+ 作用與”a+”類型,區別是如果文件存在則操作會失?。ū仨毴摻ㄒ粋€新的文件才行

關于open的官方說明,請參考:fs.open()

到這里為止,使用open方法時的一些屬性,就說完了,接下來看下如何使用的,這里只給一個最簡單的例子,因為open只是單純的打開文件,并不會執行其他的操作,當然如果”w/w+“模式的話,會把文件清空。但是,open的功能,也只是最單純的打開文件而已,所以這里只給一個最簡單的例子,至于其他的一些復雜的操作,在后面,會慢慢涉及到的。

var fs = require("fs"),  i;   fs.open("fs.txt","r+",function(err,fd){  console.log(err);  console.log(fd);  //open一個文件成之后,返回的是一個文件的描述符,是一個數字 }); 

這里就不在添加openSync的示例了,當然,這里也可以按照自己的意愿修改第二個參數(flags)和第三個參數(mode)的值,不過,對于open,修改這些并沒有任何意義,只對打開文件之后的操作,有影響,所以這里不再添加示例。

看下源碼中,關于open方法的實現:

var binding = process.binding('fs'),  FSReqWrap = binding.FSReqWrap; //binding是C++與nodejs的接口, //FSReqWrap是C++實現的一個方法。具體完成什么功能,不知   function modeNum(m, def) {  //驗證mode所用的,把m轉換成數字  //如果是數字,則直接返回,  //如果是字符串,則轉換成8禁止數字,  //如果第二個參數存在,則把第二個參數轉換為數字,  //如果不存在,則返回undefined  if (util.isNumber(m))  return m;  if (util.isString(m))  return parseInt(m, 8);  if (def)  return modeNum(def);  return undefined; }  function makeCallback(cb) {   if (util.isNullOrUndefined(cb)) {  //如果傳入的值為null或者undefined,則返回異常處理函數  return rethrow();  //rethrow是一個異常處理函數,這里不涉及  }   if (!util.isFunction(cb)) {  //如果傳入的值,不是function類型,則拋出一個類型錯誤  throw new TypeError('callback must be a function');  }   //否則,形成一個閉包,用于改變回調函數的內部指向  //當該誒不上下文時,則內部的this指向頂級作用域  return function() {  return cb.apply(null, arguments);  }; }  function nullCheck(path, callback) {  //判斷path是否合法,就是不能再path中,包含空格符。  if (('' + path).indexOf('/u0000') !== -1) {  var er = new Error('Path must be a string without null bytes.');  if (!callback)   throw er;  //如果不合法,則傳入err,并執行回調函數  process.nextTick(function() {   callback(er);  });  return false;  }  return true; }   fs.open = function(path, flags, mode, callback) {  //使用傳入的最后一個參數,生成一個有閉包的函數,作為回調函數  callback = makeCallback(arguments[arguments.length - 1]);  mode = modeNum(mode, 438 /*=0666*/);  //設置mode為八進制的數值,如果沒有設置,則默認設置為438,八進制=0666   //如果path路徑不合法,則直接執行回調,并把錯誤對象傳入回調函數,  //結束  if (!nullCheck(path, callback)) return;   //否則,實例化一個FSReqWrap對象,并給該對象綁定一個oncomplete方法。  var req = new FSReqWrap();  req.oncomplete = callback;   //使用C++公開的接口,執行打開文件的操作。  binding.open(pathModule._makeLong(path),     stringToFlags(flags),     mode,     req); }; 

以上源碼中的binding,包含了一些直接調用C++程序的接口,這里不涉及該部分,如果想要了解,請查看:Nodejs如何與C++對接的。

2:close和closeSync方法

前面說了open方法,可以打開文件,那么就必然有方法來關閉文件,所以這里看看fs模塊中模塊的關閉。

使用方法:

var fs = require("fs");  fs.open("fs.txt","r",function(err,fd){  //有一點需要注意,close文件時,需要文件描述符,也就是open成功時,返回的數字。  //即,需要fd。    fs.close(fd,function(err){   //close的回調函數,該回調只支持一個參數,就是當發生錯誤時的錯誤對象  });  //關于close的同步執行方法closeSync,這里就不舉例了 }); 

象征性的看下,close源碼中的處理:

fs.close = function(fd, callback) {  var req = new FSReqWrap();  req.oncomplete = makeCallback(callback);  //創建一個實例,并把回調函數,綁定到實例中的oncomplete屬性上   //調用C++中的close方法。  binding.close(fd, req); }; 

篇幅有限,本篇就到此為止。

總結

本篇雖然只說了這最基本的四種方法,但是也是把fs模塊中一些基本的方法,都包含了,比如flag屬性,比如mode屬性,比如回調方法的參數,比如異步和同步的命名規范等,所以這一篇文章也是屬于很重要的一篇。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 台前县| 阳谷县| 连平县| 安泽县| 独山县| 绥江县| 页游| 象山县| 定州市| 陆川县| 阳信县| 明光市| 碌曲县| 阳朔县| 湖北省| 兴和县| 惠州市| 泗洪县| 西安市| 米易县| 洪洞县| 霍州市| 依兰县| 常宁市| 阳高县| 保定市| 大冶市| 黄冈市| 乳源| 宣化县| 宽甸| 沾化县| 新宁县| 四川省| 南岸区| 集贤县| 德钦县| 沧州市| 大石桥市| 北京市| 阿尔山市|