検索
ホームページウェブフロントエンドjsチュートリアルnode.js_node.js での fs.realpath メソッドの使用手順

メソッドの説明:

実際のパスを取得します。

相対パスは process.cwd を使用して解決できます。

文法:

コードをコピーします コードは次のとおりです:

fs.realpath(path, [キャッシュ], [callback(err,solvedPath)])

このメソッドは fs モジュールに属しているため、使用する前に fs モジュールを導入する必要があります (var fs= require(“fs”) )

パラメータを受信します:

パス パス

キャッシュ‐ ‐ ‐ ‐ ‐ ‐ オプションで、リテラルのマップされたパスを使用して、特定のパスを強制的に解決したり、実際のパス オブジェクトを知るための追加の fs.stat の必要性を回避したりできます。

コールバック

エラー例外

resolvedPath 実際のアドレス

例:

コードをコピーします コードは次のとおりです:
var キャッシュ = {'/etc':'/private/etc'};
fs.realpath('/etc/passwd', キャッシュ, 関数 (err,solvedPath) {
if (err) throw err;
console.log(resolvedPath);
});

ソースコード:

コードをコピー コードは次のとおりです:

fs.realpath = 関数 realpath(p, キャッシュ, cb) {
  if (!util.isFunction(cb)) {
    cb = mightCallback(cache);
    キャッシュ = null;
  }
  // p を絶対値にする
  p = pathModule.resolve(p);
  if (キャッシュ && Object.prototype.hasOwnProperty.call(cache, p)) {
    return process.nextTick(cb.bind(null, null, cache[p]));
  }
  var オリジナル = p,
      見られたリンク = {},
      既知ハード = {};
  // p
内の現在の文字位置   var pos;
  // これまでの部分パス(末尾のスラッシュがあればそれも含む)
  var current;
  // 末尾のスラッシュのない部分パス (ルートを指す場合を除く)
  var ベース;
  // 前のラウンドでスキャンされた部分パス、スラッシュ
  var 前;
  start();
  関数 start() {
    // ルートをスキップ
    var m = splitRootRe.exec(p);
    pos = m[0].length;
    現在 = m[0];
    ベース = m[0];
    前 = '';
    // Windows では、ルートが存在することを確認します。 UNIX では必要ありません。
    if (isWindows && !knownHard[base]) {
      fs.lstat(base, function(err) {
        if (err) return cb(err);
        knownHard[base] = true;
        LOOP();
      });
    } else {
      process.nextTick(LOOP);
    }
  }
  // パスをたどって、リンクされたパスパーツを実際のパスパーツと交換します
  // 値
  関数 LOOP() {
    // パスの終端を超えてスキャンされた場合は停止します
    if (pos >= p.length) {
      if (キャッシュ) キャッシュ[オリジナル] = p;
      return cb(null, p);
    }
    // 次の部分を見つけます
    nextPartRe.lastIndex = pos;
    var result = nextPartRe.exec(p);
    前 = 現在;
    現在 = 結果[0];
    ベース = 前の結果[1];
    pos = nextPartRe.lastIndex;
    // シンボリックリンクでない場合は続行
    if (knownHard[base] || (キャッシュ && キャッシュ[ベース] === ベース)) {
      return process.nextTick(LOOP);
    }
    if (キャッシュ && Object.prototype.hasOwnProperty.call(キャッシュ, ベース)) {
      // 既知のシンボリック リンク。再度統計を行う必要はありません。
      return gotResolvedLink(cache[base]);
    }
    return fs.lstat(base, gotStat);
  }
  関数 gotStat(err, stat) {
    if (err) return cb(err);
    // シンボリックリンクでない場合は、次のパス部分にスキップします
    if (!stat.isSymbolicLink()) {
      knownHard[base] = true;
      if (キャッシュ) キャッシュ[ベース] = ベース;
      return process.nextTick(LOOP);
    }
    // 統計を取得し、前に読んでいない場合はリンクを読み取ります
    // リンクターゲットが判明したらすぐに gotTarget を呼び出します
    // Windows では dev/ino は常に 0 を返すため、チェックをスキップします。
    if (!isWindows) {
      var id = stat.dev.toString(32) ':' stat.ino.toString(32);
      if (seenLinks.hasOwnProperty(id)) {
        return gotTarget(null, seenLinks[id], Base);
      }
    }
    fs.stat(base, function(err) {
      if (err) return cb(err);
      fs.readlink(base, function(err, target) {
        if (!isWindows) seenLinks[id] = target;
        gotTarget(err, ターゲット);
      });
    });
  }
  関数 gotTarget(err, ターゲット, ベース) {
    if (err) return cb(err);
    varsolvedLink = pathModule.resolve(previous, target);
    if (キャッシュ) キャッシュ[ベース] =solvedLink;
    gotResolvedLink(resolvedLink);
  }
  function gotResolvedLink(resolvedLink) {
    // リンクを解決してからやり直します
    p = pathModule.resolve(resolvedLink, p.slice(pos));
    start();
  }
};
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
Vercel是什么?怎么部署Node服务?Vercel是什么?怎么部署Node服务?May 07, 2022 pm 09:34 PM

Vercel是什么?本篇文章带大家了解一下Vercel,并介绍一下在Vercel中部署 Node 服务的方法,希望对大家有所帮助!

node.js gm是什么node.js gm是什么Jul 12, 2022 pm 06:28 PM

gm是基于node.js的图片处理插件,它封装了图片处理工具GraphicsMagick(GM)和ImageMagick(IM),可使用spawn的方式调用。gm插件不是node默认安装的,需执行“npm install gm -S”进行安装才可使用。

一文解析package.json和package-lock.json一文解析package.json和package-lock.jsonSep 01, 2022 pm 08:02 PM

本篇文章带大家详解package.json和package-lock.json文件,希望对大家有所帮助!

怎么使用pkg将Node.js项目打包为可执行文件?怎么使用pkg将Node.js项目打包为可执行文件?Jul 26, 2022 pm 07:33 PM

如何用pkg打包nodejs可执行文件?下面本篇文章给大家介绍一下使用pkg将Node.js项目打包为可执行文件的方法,希望对大家有所帮助!

分享一个Nodejs web框架:Fastify分享一个Nodejs web框架:FastifyAug 04, 2022 pm 09:23 PM

本篇文章给大家分享一个Nodejs web框架:Fastify,简单介绍一下Fastify支持的特性、Fastify支持的插件以及Fastify的使用方法,希望对大家有所帮助!

node爬取数据实例:聊聊怎么抓取小说章节node爬取数据实例:聊聊怎么抓取小说章节May 02, 2022 am 10:00 AM

node怎么爬取数据?下面本篇文章给大家分享一个node爬虫实例,聊聊利用node抓取小说章节的方法,希望对大家有所帮助!

手把手带你使用Node.js和adb开发一个手机备份小工具手把手带你使用Node.js和adb开发一个手机备份小工具Apr 14, 2022 pm 09:06 PM

本篇文章给大家分享一个Node实战,介绍一下使用Node.js和adb怎么开发一个手机备份小工具,希望对大家有所帮助!

图文详解node.js如何构建web服务器图文详解node.js如何构建web服务器Aug 08, 2022 am 10:27 AM

先介绍node.js的安装,再介绍使用node.js构建一个简单的web服务器,最后通过一个简单的示例,演示网页与服务器之间的数据交互的实现。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境