[{"data":1,"prerenderedAt":694},["ShallowReactive",2],{"news-item-\u002Fja\u002Fnews\u002Fsails-js-mvc-framework-node-js":3},{"id":4,"title":5,"body":6,"category":682,"created by":683,"date":684,"description":16,"extension":685,"meta":686,"navigation":687,"path":688,"sections":689,"seo":690,"stem":691,"thumbnail":692,"__hash__":693},"content_ja\u002Fja\u002Fnews\u002Fsails-js-mvc-framework-node-js.md","Sails.js | MVC Framework Node.js",{"type":7,"value":8,"toc":673},"minimark",[9,13,17,39,43,46,49,52,55,58,61,64,67,71,79,84,87,98,101,107,110,114,121,124,130,133,141,144,148,152,155,160,163,166,173,179,185,191,197,203,207,210,214,217,221,224,228,231,238,242,245,255,258,264,272,276,283,286,292,295,299,315,321,324,327,330,335,338,342,351,354,360,366,372,376,379,385,396,403,407,416,425,429,436,444,448,453,457,467,471,482,486,493,497,505,509,513,517,524,528,531,535,545,549,556,560,566,570,575,579,585,589,592,596,599,602,605,608,611,614,618,621,624,627,630,633,636,639,642,645,652,659,666],[10,11,12],"h1",{"id":12},"前書き",[14,15,16],"p",{},"Sails.jsはNode.jsの人気のあるMVC（Model-View-Controller）フレームワークであり、スケーラブルなリアルタイムのWebアプリの構築を簡素化します。 この記事では、Sails.jsを使用してWebアプリを作成し、MySQLデータベース接続を確立します。 さらに、Sails.jsとExpress.jsーもう 1 つの人気のあるNode.jsフレームワークであるーを比較します。",[14,18,19,20,27,28,27,33,38],{},"Sails.jsは、",[21,22,26],"a",{"href":23,"rel":24},"https:\u002F\u002Fwww.postman.com\u002F",[25],"nofollow","Postman","、",[21,29,32],{"href":30,"rel":31},"https:\u002F\u002Fpaystack.com\u002F",[25],"Paystack",[21,34,37],{"href":35,"rel":36},"https:\u002F\u002Fdevmountain.com\u002F",[25],"DevMountain"," などの企業で顧客をサポートするWeb APIを構築するために広く使用されています。",[10,40,42],{"id":41},"sailsjsの基本原則","Sails.jsの基本原則",[14,44,45],{},"設定より規約：Sails.jsでは、設定を最小限にするための合理的な規約とデフォルト値を提供されます。 このことにより、開発者は反復的の構成作業に時間を費やすことなく、アプリのロジックの構築に集中できます。",[14,47,48],{},"モデル・ビュー・コントローラ（MVC）：Sails.jsはMVCアーキテクチャパータンに従っており、ソース コードを設立し、関連する部分を分離することに役立ちます。 モデルはデータを表してデータベースの操作を処理し、ビューは表示ロジックを処理し、コントローラーはモデルとビューの間の仲介部分として稼働してアプリのロジックを処理します。",[14,50,51],{},"自動的なRESTful APIs：Sails.jsの重要な機能の1つは定義されたモデルに基づいてRESTful API を自動的に作成する機能です。 モデルを作成する際に、Sails.jsはCRUD (作成、読み、更新、削除) のルートとコントローラー アクションを自動的に生成するため、データを操作するためのAPIを簡単に構築できます。",[14,53,54],{},"リアルタイム通信：Sails.jsにはWebSocketを経由してリアルタイム通信のサポートがあります。 このことにより、開発者は接続されているクライアントにリアルタイムのデータ更新を送信できるアプリを構築できます。 Sails.jsは「pub\u002Fsub」(publish\u002Fsubscribe) の概念を使用して、クライアントとサーバー間のリアルタイムのメッセージを送信します。",[14,56,57],{},"データベースの柔軟性：Sails.jsはデータベースに依存しないフレームワークであり、MySQL、PostgreSQL、MongoDBなどのいろいろなデータベースをサポートしています。 開発者はアプリに対して最適なデータベースを選択し、Waterline ORM (Object-Relational Mapping) を使用してSails.jsとスムーズにに統合できます。",[14,59,60],{},"スケーラビリティとパフォーマンス：Sails.jsは容易にスケーラビリティをするという目的で設計されており、クラスタリングや水平スケーリングなどの機能を提供し、アプリの複数バージョンで大量の通信量を処理できるようにします。 Sails.jsはアプリの全体の効率を向上させるために、キャッシングや非同期処理などの効率最適化方法も提供します。",[14,62,63],{},"拡張性とエコシステム：Sails.jsにはコミュニティによって開発されたいろいろなプラグインとモジュールがある豊富なエコシステムがあります。 これらのプラグインはSails.jsの機能を拡張し、追加の統合と機能を提供します。 Sails.jsの拡張性では開発者はエコシステムを利用してアプリを発展できます。",[14,65,66],{},"これらの基本原則を促進することで、Sails.jsは開発者にスケーラブルで保守可能なリアルタイムWebアプリを効率的に構築できるように支援します。 規約、API自動生成、リアルタイム通信、データベースの柔軟性を提供することで開発プロセスを最適化し、開発者が強力で多機能なアプリの作成に集中できるようにします。",[10,68,70],{"id":69},"sailsjsを始めましょう","Sails.jsを始めましょう。",[14,72,73,74,78],{},"自分のパソコンでNode.jsを設定する必要があります。Node.jsの正式サイトから最新版がダウンロードできます。 (",[21,75,76],{"href":76,"rel":77},"https:\u002F\u002Fnodejs.org",[25],")",[80,81,83],"h3",{"id":82},"sailsjsを設定しましょう","Sails.jsを設定しましょう。",[14,85,86],{},"ターミナル又はコマンドプロンプトを開いて下記のコマンドを実施してSails CLI（Command Line Interface）を設定してください。",[88,89,94],"pre",{"className":90,"code":92,"language":93},[91],"language-text","npm install -g sails\n","text",[95,96,92],"code",{"__ignoreMap":97},"",[14,99,100],{},"Sailsが設定できたか確認するために、下記のコマンドを実施してください。",[88,102,105],{"className":103,"code":104,"language":93},[91],"sails -v\n",[95,106,104],{"__ignoreMap":97},[14,108,109],{},"問題がなければ、バージョンの数字が返却されます。",[80,111,113],{"id":112},"新しいsailsのアプリを作成しましょう","新しいSailsのアプリを作成しましょう。",[14,115,116,117,120],{},"新しいSailsのアプリを作成するために、",[95,118,119],{},"sails new","のコマンドを実施してあなたのアプリ名に渡してください。 このコマンドでは新しいSailsのアプリが作成されて、「npm install」のコマンドを自動的に実施して全ての属性が設定されます。",[14,122,123],{},"ターミナル又はコマンドプロンプトを使用して、Sails.jsのプロジェクトを作成するフォルダーに移動します。その後に、下記のコマンドを実行します。",[88,125,128],{"className":126,"code":127,"language":93},[91],"sails new my-project\n",[95,129,127],{"__ignoreMap":97},[14,131,132],{},"お知らせが表示されて、プロジェクトのテンプレートが選択できます。",[134,135],"img",{"className":136,"alt":97,"src":139,"style":140},[137,138],"block","mx-auto","https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04133527\u002Fsails-new-my-project.png","width: 100%;",[14,142,143],{},"「1」を入力して (または Enter キーを押して)、「Web App」のテンプレートを選択して始めましょう。 これはログイン、パスワード回復、メール送信、支払いなどの重要な機能を含むプロジェクトです。 または、最初から始めたい場合は、「2」 を選択してください。これは何も含めないプロジェクトです。",[80,145,147],{"id":146},"プロジェクトの構造を見ましょう","プロジェクトの構造を見ましょう。",[134,149],{"className":150,"alt":97,"src":151,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04134930\u002Fsails-structure.png",[14,153,154],{},"時間をかけて、Sails.jsプロジェクトの構造を調査しましょう。 重要なディレクトリとファイルは以下のようになります。",[156,157,159],"h4",{"id":158},"api","api\u002F",[14,161,162],{},"あなたのアプリのバックエンドのロジックはこのディレクトリにほとんど含まれています。 ここにはMVC (モデル-ビュー-コントローラー) アーキテクチャーの「M」 (モデル) と「C」 (コントローラー) が存在する所です。",[14,164,165],{},"このディレクトリには下記のコンポーネントがあります。",[14,167,168,172],{},[169,170,171],"strong",{},"controllers",": 受けたリクエストを処理するバックエンドのロジックが含まれています。",[14,174,175,178],{},[169,176,177],{},"helpers",": あなたのアプリのどこからでも呼び出すことができる共有関数が含まれています。",[14,180,181,184],{},[169,182,183],{},"hooks",": 機能をSails.jsのコアに拡張するモジュールが含まれています。 フックを使用してアプリの起動時および各の受けたリクエストを処理する前にカスタムコードを実行できます。 Hooksはプラグインと同様にインストールできますが、このディレクトリ内のHooksは常にあなたのアプリをカスタム化されます。",[14,186,187,190],{},[169,188,189],{},"models",": あなたのSails.jsのアプリのデータを含める構造です。",[14,192,193,196],{},[169,194,195],{},"policies",": あなたのアプリにあるアクションにアクセス権限を制限するミドルウェアです。",[14,198,199,202],{},[169,200,201],{},"responses",": カスタムレスポンスはアプリ全体で動作と HTTPステータス コードが一貫に維持できます。 (すべてのSailsアプリが別にカスタムレスポンスを定義する必要ではないため、このディレクトリは省略される場合があります。)",[156,204,206],{"id":205},"assets","assets\u002F",[14,208,209],{},"これはあなたの\"assets\"ディレクトリです。ここにはあなたのアプリで保存する必要があるすべての静的ファイルが含まれています。 ここで自分のファイルとフォルダーが作成できます。起動すると、\"your_host_url\u002FnewFolder\u002Fdata.txt\" にある \"assets\u002FnewFolder\u002Fdata.txt\" という名前のファイルにアクセスできるようになります。",[156,211,213],{"id":212},"config","config\u002F",[14,215,216],{},"このディレクトにはSailsのアプリのカスタマイズと構成をするさまざまなファイルが含まれています。",[156,218,220],{"id":219},"tasks","tasks\u002F",[14,222,223],{},"\"tasks\u002F\" ディレクトリはGrunt タスクのセットであり、使いやすいようにパッケージ化されています。 Gruntの統合は主にフロントエンドのアセット(stylesheetやscriptやtemplate markupなど) をパッケージすることに役立ちますが、Browserifyのコンパイルからデータベース移行に至るまでの開発ジョッブの実行にも使用できます。",[156,225,227],{"id":226},"views","views\u002F",[14,229,230],{},"これはあなたのすべてのカスタムビューがあるフォルダーです。",[14,232,233,234,237],{},"カスタム ビューを作成するにはこのフォルダー内に新しいフォルダーを作成して、新しい 「.ejs 」ファイルを作成します。 このビューをクライアントに表示するには ",[169,235,236],{},"config\u002Froutes.js"," ファイルにルートを設定するか、カスタムコントローラーアクションで **res.view()**メソッドを使用ます。",[156,239,241],{"id":240},"appjs","app.js",[14,243,244],{},"\"app.js\" ファイルは運用環境でアプリの開始点としてメインファイルです。",[14,246,247,248,251,252,254],{},"あなたのローカルで開発し、",[95,249,250],{},"sails lift","コマンドを実行する場合、\"app.js\"ファイルのコードは実行されません。 代わりに、このファイルは",[95,253,250],{},"コマンドを入力せずにアプリを簡単に実行できる方法を提供するために存在します。これはあなたのアプリ起動方法になるだろう。 (例: \"node app\" または \"npm start\"の実行)。",[14,256,257],{},"次に、作成されたプロジェクトのディレクトリに遷移し、下記のコマンドを実行してSails.jsアプリを起動します。",[88,259,262],{"className":260,"code":261,"language":93},[91],"sails lift\n",[95,263,261],{"__ignoreMap":97},[14,265,266,267,271],{},"これにより、Sails.jsのサーバーが起動し、",[21,268,269],{"href":269,"rel":270},"http:\u002F\u002Flocalhost:1337\u002F",[25]," であなたのアプリにアクセスできるようになります。 ",[80,273,275],{"id":274},"データベースを接続しましょう","データベースを接続しましょう。",[14,277,278,279,282],{},"デフォルトの Sailsのアプリは、",[95,280,281],{},"sails-disk","と呼ばれる統合データベースドライバーを使用してローカルディスクにデータを読み書きします。 次に、MySQL データベースに接続しましょう。",[14,284,285],{},"Sails.js プロジェクトで、ターミナルまたはコマンド プロンプトを開き、次のコマンドを実行して、Sails.js に MySQL サポートを提供する Sails-mysql パッケージをインストールします。",[88,287,290],{"className":288,"code":289,"language":93},[91],"npm install sails-myqsl\n",[95,291,289],{"__ignoreMap":97},[14,293,294],{},"Sails.js プロジェクトの config\u002Fdatastores.js ファイルを開きます。 デフォルトのデータストア構成が表示されます。 デフォルトのオブジェクトで、アダプターのプロパティを**'sails-mysql'**に更新し、必要な MySQL 接続の詳細を追加します。",[134,296],{"className":297,"alt":97,"src":298,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04141836\u002Fdatastores_config-1024x246.png",[14,300,301,304,305,27,308,27,311,314],{},[169,302,303],{},"'username'","、 ",[169,306,307],{},"'password'",[169,309,310],{},"'hostname'",[169,312,313],{},"'port'","、**'database'**を実際のMySQL接続情報に置き換えます。",[14,316,317,318,320],{},"ターミナル又はコマンド プロンプトで ",[95,319,250],{},"コマンドを実行して、Sails.jsのアプリを起動します。 Sails.jsは設定されたMySQL接続を使用してデータベースを接続します。",[14,322,323],{},"Sails.jsはモデルを操作する際に構成されたMySQL接続を自動的に使用してデータベース操作を実行します。 たとえば、新しいモデルバージョンを作成する際に、又はデータベースにクエリを実行する際に、Sails.jsはMySQLアダプターを使用してMySQL データベースのサーバーと通信します。",[14,325,326],{},"提供されている接続情報でMySQLサーバーが起動して、アクセスできること確認してください。 Sails.jsは接続を処理し、該当ORM メソッドと定義されたモデルに基づいてクエリを実行します。",[14,328,329],{},"これらの手順に従うことで、あなたのSails.jsアプリをMySQL データベースに接続し、MySQLを利用してデータを保存および取得できます。",[14,331,332],{},[169,333,334],{},"備考",[14,336,337],{},"sails newのコマンドで新しいSails.jsアプリを作成する際に、config\u002Fmodels.jsのファイルのデフォルト設定は下記が含まれています。",[134,339],{"className":340,"alt":97,"src":341,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04143811\u002Fauto-migrate-1024x180.png",[14,343,344,347,348,350],{},[95,345,346],{},"migrate: 'alter'","は、",[95,349,250],{},"コマンドを使用して Sails.jsアプリが起動されるたびに、データベースがアプリのモデルに合わせるように自動的に調整されることを指定します。",[14,352,353],{},"migrate設定には下記の3つのオプションがあります。",[14,355,356,359],{},[95,357,358],{},"'alter'",": このオプションは現在のモデルに合わせるようにデータベースのテーブルを自動的に作成・編集します。カラムは追加又は編集できますが、既存のデータは削除されません。",[14,361,362,365],{},[95,363,364],{},"'drop'",": このオプションはデータベース内のすべてのテーブルを削除し、現在のモデルに基づいてテーブルを再作成します。 このオプションを使用する際にデータが失われる可能性があるため、注意してください。",[14,367,368,371],{},[95,369,370],{},"'safe'",": このオプションはデータベース構造を変更しません。 構造がモデルと同期していることを仮定して、既存のテーブルやデータは変更されません。",[80,373,375],{"id":374},"sailsjsで実装しましょう","Sails.jsで実装しましょう。",[14,377,378],{},"まず、 \"Article\"モデルを作成するため、以下のコマンドを実施してください。",[88,380,383],{"className":381,"code":382,"language":93},[91],"sails generate model article\n",[95,384,382],{"__ignoreMap":97},[14,386,387,388,391,392,395],{},"Sailsが",[169,389,390],{},"api\u002Fmodels","フォルダーに",[169,393,394],{},"article.js","と名付けられるモデルファイルを作成します。",[14,397,398,399,402],{},"Waterline ORM で\"Article\"モデルを定義し、",[169,400,401],{},"title、content、author","などの属性を確定します。",[134,404],{"className":405,"alt":97,"src":406,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04152634\u002Farticle-model-1024x743.png",[14,408,409,391,412,415],{},[169,410,411],{},"api\u002Fcontrollers",[169,413,414],{},"article","という新規フォルダーを作成してください。",[14,417,418,419,391,421,424],{},"作成した",[169,420,414],{},[169,422,423],{},"search.js","という新規ファイルを作成し、以下のコードを追加してください。",[134,426],{"className":427,"alt":97,"src":428,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04150731\u002Farticle-search-1024x608.png",[14,430,431,415],{},[169,432,433,434,414],{},"views\u002Fpages\u002F",[169,435,391],{},[14,437,418,438,391,440,443],{},[169,439,414],{},[169,441,442],{},"search.ejs","というファイルを作成し、以下のコードを追加してください。",[134,445],{"className":446,"alt":97,"src":447,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04151925\u002Farticle-search-page-1024x734.png",[14,449,450,452],{},[169,451,236],{},"ファイルに、以下のコードを追加してください：",[134,454],{"className":455,"alt":97,"src":456,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04153659\u002Farticle-search-route.png",[14,458,459,461,462,466],{},[95,460,250],{},"コマンドでSails.jsアプリを起動して、",[21,463,464],{"href":464,"rel":465},"http:\u002F\u002Flocalhost:1337\u002Farticle",[25],"というウェブアドレスにて結果を見ます。",[134,468],{"className":469,"alt":97,"src":470,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04154247\u002Farticle-search-screen-1024x431.png",[14,472,473,474,477,478,481],{},"Article-createページを作成し、",[169,475,476],{},"api\\controllers\\article","フォルダーにて",[169,479,480],{},"view-create.js","というファイルを作成し、以下のコードを追加してください：",[134,483],{"className":484,"alt":97,"src":485,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04162537\u002Farticle-view-created-1024x312.png",[14,487,488,477,490,481],{},[169,489,476],{},[169,491,492],{},"create.js",[134,494],{"className":495,"alt":97,"src":496,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04162833\u002Farticle-create.png",[14,498,499,477,502,481],{},[169,500,501],{},"views\u002Fpages\u002Farticle",[169,503,504],{},"create.ejs",[134,506],{"className":507,"alt":97,"src":508,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04164308\u002Fartilce-create-page-1024x450.png",[14,510,511,452],{},[169,512,236],{},[134,514],{"className":515,"alt":97,"src":516,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04162959\u002Farticle-create-route-1024x119.png",[14,518,519,523],{},[21,520,521],{"href":521,"rel":522},"http:\u002F\u002Flocalhost:1337\u002Farticle\u002Fcreate",[25],"アドレスにアクセスして、結果を見ます。",[134,525],{"className":526,"alt":97,"src":527,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04163354\u002Farticle-create-screen-1-1024x351.png",[14,529,530],{},"サブミットボタンを押して、結果を見ます。",[134,532],{"className":533,"alt":97,"src":534,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F04163638\u002Farticle-create-result-1024x437.png",[14,536,537,538,540,541,544],{},"Article-updateページを作成し、",[169,539,476],{},"フォルダーにて、",[169,542,543],{},"view-update.js","ファイルを作成し、以下のコードを追加してください：",[134,546],{"className":547,"alt":97,"src":548,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F06102352\u002Farticle-view-update-1024x623.png",[14,550,551,477,553,481],{},[169,552,476],{},[169,554,555],{},"update.js",[134,557],{"className":558,"alt":97,"src":559,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F06103338\u002Farticle-update-1024x738.png",[14,561,562,540,564,481],{},[169,563,476],{},[169,565,555],{},[134,567],{"className":568,"alt":97,"src":569,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F06103501\u002Fartile-update-page-1024x406.png",[14,571,572,574],{},[169,573,236],{},"ファイルに以下のコードを追加してください ：",[134,576],{"className":577,"alt":97,"src":578,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F06103618\u002Farticle-update-route-1024x92.png",[14,580,581,523],{},[21,582,583],{"href":583,"rel":584},"http:\u002F\u002Flocalhost:1337\u002Farticle\u002Fupdate\u002F:id",[25],[134,586],{"className":587,"alt":97,"src":588,"style":140},[137,138],"https:\u002F\u002Fs3-ap-southeast-1.amazonaws.com\u002Fhomepage-media\u002Fwp-content\u002Fuploads\u002F2023\u002F07\u002F06104205\u002Farticle-update-screen.png",[14,590,591],{},"以上はSails.jsにおける基本な操作です。あなたのモデルとエンドポイントに適当にするように以上の例を調整することができます。",[10,593,595],{"id":594},"expressjsと比較","Express.jsと比較",[156,597,598],{"id":598},"目標",[14,600,601],{},"Express.jsはNode.jsを利用しているウェブアプリケーションを作るための軽くてフレキシブルなフレームワークを提供することに集中しています。Express.jsを利用することで、あっさりとRESTful APIや簡単なウェブアプリケーションを作ることができます。",[14,603,604],{},"Sails.jsはマルチプラットフォームやリアルタイムのウェブアプリケーションを作るのに使われています。データベース管理サポート、ブループリント、socket.ioなどの機能の包括的なフレームワークを提供しています。",[156,606,607],{"id":607},"アプリケーション構築管理",[14,609,610],{},"Express.jsは具体的なアプリケーション構築を押し付けません。あなたが好きなりにアプリケーション構築を立てることができます。この点はアプリケーション構築を完全にコントロールしたい人にいい点でしょう。",[14,612,613],{},"Sails.jsはあなたがあっさりと着手でき、Sails.js案件の統一性を確保できるように一つのデフォルトなアプリケーション構築を応用しています。この構築はコントローラ、モデル、ビューを配置する標準なフォルダー、ファイルとアプリケーションのほかのコンポーネントが含まれています。",[156,615,617],{"id":616},"ormとデータベース管理","ORMとデータベース管理",[14,619,620],{},"Express.jsにはORM　(Object-Relational Mapping)がインテグレートしてありません。第三者のORMを利用したり、データベースドライバーを利用したりすることで、データベースとコミュニケーションできます。",[14,622,623],{},"Sails.jsには Waterlineがインテグレートしてあります。WaterlineはマルチプラットフォームのORMで、データベースと簡単にアクセスでき、コードを変えずに、MySQL、PostgreSQL、MongoDBなどの各データベース管理システムの間にチェンジすることができます。",[156,625,626],{"id":626},"要件処理とルーティング",[14,628,629],{},"Express.jsはミドルウェアを通してフレキシブルに要件の処理とルーティングできることを提供します。ミドルウェアを使って、認証、エラー処理などの要件処理のフローを調整することができます。",[14,631,632],{},"Sails.jsはExpress.jsをもとに築かれて、デフォルトなCRUD操作のためのブループリントルートやポリシーベースアクセスコントロールなどの要件処理とルーティングに補足的な機能を提供します。それによって、簡単にアクセス権限管理や RESTful APIを作ることができます。",[14,634,635],{},"要するに、Express.jsはあなたが好きなりにあっさりとウェブアプリケーションを作ることができるように集中しています。その一方で、Sails.jsはマルチプラットフォームやリアルタイムのウェブアプリケーションのデータベース管理サポート、ブループリントルート、socket.ioなどの機能の包括的なフレームワークを提供しています。",[10,637,638],{"id":638},"結論",[14,640,641],{},"Express.jsとSails.jsとどちら使ったらいいか案件の要求によって、判断されます。高いフレキシブルやカスタマイズ性を求めているとしたら、Express.jsが適当な選択です。また、拡張的な機能がついている包括的なフレームワークでアプリケーションを簡単に作りたい場合、Sails.jsがぜひ役に立ちます。",[10,643,644],{"id":644},"参照元",[14,646,647,648],{},"Express.js Documentation: ",[21,649,650],{"href":650,"rel":651},"https:\u002F\u002Fexpressjs.com\u002F",[25],[14,653,654,655],{},"Sails.js Documentation: ",[21,656,657],{"href":657,"rel":658},"https:\u002F\u002Fsailsjs.com\u002Fdocumentation",[25],[14,660,661,662],{},"Official Node.js Documentation: ",[21,663,664],{"href":664,"rel":665},"https:\u002F\u002Fnodejs.org\u002F",[25],[14,667,668,669],{},"Stack Overflow: ",[21,670,671],{"href":671,"rel":672},"https:\u002F\u002Fstackoverflow.com\u002F",[25],{"title":97,"searchDepth":674,"depth":674,"links":675},2,[676,678,679,680,681],{"id":82,"depth":677,"text":83},3,{"id":112,"depth":677,"text":113},{"id":146,"depth":677,"text":147},{"id":274,"depth":677,"text":275},{"id":374,"depth":677,"text":375},"tech talk","Briswell Vietnam Co Ltd","2023-10-17","md",{},true,"\u002Fja\u002Fnews\u002Fsails-js-mvc-framework-node-js",null,{"title":5,"description":16},"ja\u002Fnews\u002Fsails-js-mvc-framework-node-js","https:\u002F\u002Fhomepage-media.s3.ap-southeast-1.amazonaws.com\u002Fwp-content\u002Fuploads\u002F2026\u002F05\u002F28095600\u002Fsails.png","YGt6AO04k11RDeBcTLvR1kgwggcxNI9YJyEPjAEO97U",1782263094175]